## IP CORE MANUAL



# AXI4-Stream Data Flow Control and Packetizer 2 IP

px\_axis\_pdti2ppkt\_2



Pentek, Inc.
One Park Way
Upper Saddle River, NJ 07458
(201) 818–5900
http://www.pentek.com/

Copyright © 2017

Manual Part Number: 807.48394 Rev: 1.2 – July 31, 2017

#### **Manual Revision History**

| <u>Date</u> | <b>Version</b> | <u>Comments</u>                                                                                                                                                                                                                                     |
|-------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 05/08/17    | 1.0            | Initial Release                                                                                                                                                                                                                                     |
| 7/6/17      | 1.1            | Revised IP Facts, Sect 1.1, Table 3–1, Table 3–2, Table 3–3, Sect 4.1, Table 4–2, Table 4–3, Table 4–4, Table 4–5, Table 4–10, Sect 5.2, Sect 5.3. Created new Programming Sequence Diagram: Sect 5.7. Assigned new part number (was 388, now 394). |
| 7/31/17     | 1.2            | Revised Sect 4.10, Sect 4.11, and Sect 4.12 to include bad_trigger.                                                                                                                                                                                 |

#### **Legal Notices**

The information disclosed to you hereunder (the "Materials") is provided solely for the selection and use of Pentek products. To the maximum extent permitted by applicable law: (1) Materials are made available "AS IS" and with all faults, Pentek hereby DISCLAIMS ALL WARRANTIES AND CONDITIONS, EXPRESS, IMPLIED, OR STATUTORY, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, NON-INFRINGEMENT, OR FITNESS FOR ANY PARTICULAR PURPOSE; and (2) Pentek shall not be liable (whether in contract or tort, including negligence, or under any other theory of liability) for any loss or damage of any kind or nature related to, arising under, or in conjunction with, the Materials (including your use of Materials), including for any direct, indirect, special, incidental, or consequential loss or damage (including loss of data, profits, goodwill, or any type of loss or damage suffered as a result of any action brought by a third party) even if such damage and loss was reasonably foreseeable or Pentek had been advised of the possibility of the same. Pentek assumes no obligation to correct any error contained in the Materials or to notify you of updates to the Materials or to product specifications. You may not reproduce, modify, distribute, or publicly display the materials without prior written consent. Certain products are subject to the terms and conditions of Pentek's limited warranty, please refer to Pentek's Ordering and Warranty information which can be viewed at http://www.pentek.com/ contact/customerinfo.cfm; IP cores may be subject to warranty and support terms contained in a license issued to you by Pentek. Pentek products are not designed or intended to be fail-safe or for use in any application requiring fail-safe performance; you assume sole risk and liability for the use of Pentek products in such critical applications.

#### Copyright

Copyright © 2017, Pentek, Inc. All Rights Reserved. Contents of this publication may not be reproduced in any form without written permission.

#### **Trademarks**

Pentek, Jade, and Navigator are trademarks or registered trademarks of Pentek, Inc.

ARM and AMBA are registered trademarks of ARM Limited. PCI, PCI Express, PCIe, and PCI–SIG are trademarks or registered trademarks of PCI–SIG. Xilinx, Kintex UltraScale, Vivado, and Platform Cable USB are registered trademarks of Xilinx Inc., of San Jose, CA.

|        |                                                                          | Page |
|--------|--------------------------------------------------------------------------|------|
|        | IP Facts                                                                 |      |
| Descri | ption                                                                    | 7    |
|        | res                                                                      |      |
|        | 1–1: IP Facts Table                                                      |      |
|        | Chapter 1: Overview                                                      |      |
| Functi | ional Description                                                        | 9    |
|        | e 1–1: AXI4–Stream Data Flow Control and Packetizer 2 Core Block Diagram |      |
|        | cations                                                                  |      |
|        | n Requirements                                                           |      |
| 2      | sing and Ordering Information                                            |      |
|        | cting Technical Support                                                  |      |
|        | nentation                                                                |      |
|        | Chapter 2: General Product Specifications                                |      |
|        | ards                                                                     |      |
|        | mance                                                                    |      |
| 2.2.1  | Maximum Frequencies                                                      |      |
|        | rce Utilization2–1: Resource Usage and Availability                      |      |
|        | ations and Unsupported Features                                          |      |
|        | ic Parameters                                                            |      |
| Gener  | ic i arameters                                                           | 14   |
|        | Chapter 3: Port Descriptions                                             |      |
| AXI4-  | -Lite Core Interfaces                                                    | 15   |
| 3.1.1  | Control/Status Register (CSR) Interface                                  |      |
|        | Table 3-1: Control/Status Register (CSR) Interface Port Descriptions     |      |
| AXI4-  | -Stream Core Interfaces                                                  |      |
| 3.2.1  | Combined Sample Data/Timestamp/Information Streams (PDTI) Interface      | 18   |
|        | Table 3–2: Combined Sample Data/ Timestamp/ Information Streams          |      |
|        | Interface Port Descriptions                                              |      |
| 3.2.2  | Packetized Sample Data/ Timestamp/ Information Streams (PPKT) Interface  | 20   |
|        | Table 3-3: Packetized Sample Data/ Timestamp/ Information Streams        | _    |
|        | Interface Port Descriptions                                              | 20   |

Page

## Chapter 4: Register Space

|      | Table 4-1: Register Space Memory Map                              | <b>2</b> 3 |
|------|-------------------------------------------------------------------|------------|
| 4.1  | Mode Control Register                                             |            |
|      | Figure 4–1: Mode Control Register                                 | 24         |
|      | Table 4–2: Mode Control Register (Base Address + 0x00)            | 25         |
| 4.2  | Trigger Clear Register                                            | 27         |
|      | Figure 4–2: Trigger Clear Register                                |            |
|      | Table 4–3: Trigger Clear Register (Base Address + 0x04)           | 27         |
| 4.3  | Trigger Delay Value Register                                      | 28         |
|      | Figure 4–3: Trigger Delay Value Register                          |            |
|      | Table 4-4: Trigger Delay Value Register (Base Address + 0x08)     | 28         |
| 4.4  | Trigger Length Value Register                                     | 29         |
|      | Figure 4–4: Trigger Length Value Register                         |            |
|      | Table 4-5: Trigger Length Value Register (Base Address + 0x0C)    | <b>2</b> 9 |
| 4.5  | Timestamp Start (Lower) Register                                  | 30         |
|      | Figure 4–5: Timestamp Start (Lower) Register                      | 30         |
|      | Table 4–6: Timestamp Start (Lower) Register (Base Address + 0x10) | 30         |
| 4.6  | Timestamp Start (Upper) Register                                  |            |
|      | Figure 4–6: Timestamp Start (Upper) Register                      | 31         |
|      | Table 4-7: Timestamp Start (Upper) Register (Base Address + 0x14) | 31         |
| 4.7  | Timestamp End (Lower) Register                                    | 32         |
|      | Figure 4–7: Timestamp End (Lower) Register                        | 32         |
|      | Table 4–8: Timestamp End (Lower) Register (Base Address + 0x18)   | 32         |
| 4.8  | Timestamp End (Upper) Register                                    | 33         |
|      | Figure 4–8: Timestamp End (Upper) Register                        | 33         |
|      | Table 4-9: Timestamp End (Upper) Register (Base Address + 0x1C)   | 33         |
| 4.9  | Status Register                                                   | 34         |
|      | Figure 4–9: Status Register                                       | 34         |
|      | Table 4-10: Status Register (Base Address + 0x20)                 | 34         |
| 4.10 | Interrupt Enable Register                                         |            |
|      | Figure 4–10: Interrupt Enable Register                            | 35         |
|      | Table 4–11: Interrupt Enable Register (Base Address + 0x34)       | 35         |
| 4.11 | Interrupt Status Register                                         | 37         |
|      | Figure 4–11: Interrupt Status Register                            | 37         |
|      | Table 4–12: Interrupt Status Register (Base Address + 0x38)       |            |
| 4.12 | Interrupt Flag Register                                           |            |
|      | Figure 4–12: Interrupt Flag Register                              |            |
|      | Table 4-13: Interrupt Flag Register (Base Address + 0x3C)         | 39         |

|     |                                                                                 | Page |
|-----|---------------------------------------------------------------------------------|------|
|     | Chapter 5: Designing with the Core                                              |      |
| 5.1 | General Design Guidelines                                                       | 41   |
| 5.2 | Clocking                                                                        |      |
| 5.3 | Resets                                                                          | 41   |
| 5.4 | Interrupts                                                                      | 41   |
| 5.5 | Interface Operation                                                             | 42   |
| 5.6 | Timing Diagrams                                                                 |      |
| 5.7 | Programming Sequence Diagram                                                    | 43   |
| 6.1 | Chapter 6: Design Flow Steps  Pentek IP Catalog                                 | 45   |
| 0.1 | Figure 6–1: AXI4–Stream Data Flow Control and Packetizer 2 Core in Pentek IP Ca |      |
|     | Figure 6–2: AXI4–Stream Data Flow Control and Packetizer 2 Core IP Symbol       | _    |
| 6.2 | User Parameters                                                                 |      |
| 6.3 | Generating Output                                                               |      |
| 6.4 | Constraining the Core                                                           |      |
| 6.5 | Simulation                                                                      | 48   |
|     | Table 6-1: Test Parameters File Contents and Parameter Descriptions             | 48   |
|     | Figure 6-3: AXI4-Stream Data Flow Control and Packetizer 2 Core                 |      |
|     | Test Bench Simulation Output                                                    | 49   |
|     |                                                                                 |      |

Page

This page is intentionally blank

### IP Facts

#### Description

Pentek's Navigator<sup>TM</sup> AXI4-Stream Data Flow Control and Packetizer Type-2 Core controls the flow of input AXI4–Stream and generates a packed output AXI4-Stream, where the start and end of packet are controlled either by a gate signal or trigger signal or a timestamp range. This core is a Packetizer Type-2 core which accepts input data having 2 samplesper-clock-cycle real data streams or one complex sample-per-clock-cycle 16-bit I/Q data stream, or 32-bit complex I followed by Q data. This core generates a data acquisition gate signal based on the selected source (gate/ trigger/ timestamp range) to control the data flow, and generates packed data synchronized to the acquisition gate.

This core complies with the ARM® AMBA® AXI4 Specification and also provides a control/status register interface. This user manual defines the hardware interface, software interface, and parameterization options for the AXI4–Stream Data Flow Control and Packetizer 2 Core.

#### **Features**

- Supports I/Q packed and 32-bit real input data streams
- Supports only two sample-per-clock-cycle input data real streams
- Register access through AXI4–Lite interface
- Start and end of packet can be controlled by gate or trigger or a timestamp range which is user-defined
- User–programmable trigger length, trigger delay, and timestamp range
- Generates interrupts for start and end of acquisition gate
- Supports local register controlled gate signal

| Table 1–1: IP Facts Table                 |                                                     |  |  |  |  |
|-------------------------------------------|-----------------------------------------------------|--|--|--|--|
| Core Specifics                            |                                                     |  |  |  |  |
| Supported Design<br>Family <sup>a</sup>   | Kintex <sup>®</sup> Ultrascale                      |  |  |  |  |
| Supported User<br>Interfaces              | AXI4-Lite and AXI4-<br>Stream                       |  |  |  |  |
| Resources                                 | See Table 2-1                                       |  |  |  |  |
| Provided with the Cor                     | e                                                   |  |  |  |  |
| Design Files                              | VHDL                                                |  |  |  |  |
| Example Design                            | Not Provided                                        |  |  |  |  |
| Test Bench                                | VHDL                                                |  |  |  |  |
| Constraints File                          | Not Provided <sup>b</sup>                           |  |  |  |  |
| Simulation Model                          | VHDL                                                |  |  |  |  |
| Supported S/W<br>Driver                   | HAL Software Support                                |  |  |  |  |
| <b>Tested Design Flows</b>                |                                                     |  |  |  |  |
| Design Entry                              | Vivado <sup>®</sup> Design Suite<br>2017.1 or later |  |  |  |  |
| Simulation                                | Vivado VSim                                         |  |  |  |  |
| Synthesis                                 | Vivado Synthesis                                    |  |  |  |  |
| Support                                   |                                                     |  |  |  |  |
| Provided by Pentek fpgasupport@pentek.com |                                                     |  |  |  |  |

a.For a complete list of supported devices, see the *Vivado Design Suite Release Notes*.

 b.Clock constraints can be applied at the top level module of the user design.

| AXI4-Stream                           | Data  | F1070               | Control                 | and   | Packetizes          | r 2        | ΙP  |
|---------------------------------------|-------|---------------------|-------------------------|-------|---------------------|------------|-----|
| $\Delta \Delta 14 - 311 \epsilon u m$ | 1/414 | $\Gamma L U \omega$ | $\mathbf{L}$ . $OHLIOL$ | u n u | F U.C.N.P.L.L.Z.P.I | <i>Z</i> . | 1 1 |

Page 8

This page is intentionally blank

## Chapter 1: Overview

#### 1.1 Functional Description

The Packetizer Core (Pentek AXI4–Stream Data Flow Control and Packetizer 2 Core) accepts combined Sample Data/ Timestamp/ Information AXI4–Streams, which include sample data, a timestamp with a time–aligned copy of the timing events (gate, sync, PPS), and data information (see Section 3.2), and generates packed output AXI4–Streams which include the packetized data, timestamp, and data information.

This core has a Register Space which includes the control, status, and interrupt registers, which can be accessed using the AXI4–Lite Interface as shown in Figure 1–1. It also has an AXI Clock Converter Core in order to operate the Register Space in the AXI4–Stream clock domain.

The Packetizer Core has a Gate/ Trigger Generator Module which generates a data acquisition gate signal to control the data flow based on the mode select bits defined in the mode control register of the core (see Section 4.1). The Packetizer Core can operate in four modes, where each mode defines the source of the data acquisition gate signal.

- **Gate mode**: The data acquisition gate signal is generated from the input gate signal or a local register controlled gate signal.
- **Trigger mode:** The gate input signal is used as a trigger to generate a data acquisition gate signal which has a trigger delay and trigger length defined by the control registers in the Register Space (see Chapter 4).
- **Trigger Hold mode:** The gate input signal is used as a trigger to generate a data acquisition gate signal which remains active until the Trigger Control State Machine is reset.
- **Timestamp mode:** The data acquisition gate signal is generated for a timestamp range defined by the user through the timestamp control registers (see Chapter 4).

The Packetizer Core has a Trigger Control State Machine which is used to generate the packetized data output for the acquisition gate period. The mode control register is used to control the Trigger Control State Machine (see Table 4–2). The Packetizer Core also provides edge detection of the active data acquisition gate period for use in creating gate event interrupts.

Figure 1–1 is a top–level block diagram of the Pentek AXI4–Stream Data Flow Control and Packetizer 2 Core. The modules within the block diagram are explained in the later sections of this user manual.

#### **1.1** Functional Description (continued)

Interrupt AXI4-Lite Output Interface **AXI Clock** AXI4-Lite Register Converter Interface Space Control and Status Signals **Control Signals** AXI4 **AXI Stream Clock** Stream Gate/ Trigger Clock **Packed** Input AXI4-Stream Gate **Packetized** AXI4-Stream AXI4-Stream **Generator Module** AXI4-Stream Trigger Control Data Reset Master Interface Slave Interface Output State Machine Reset

Figure 1–1: AXI4–Stream Data Flow Control and Packetizer 2 Core Block Diagram

- AXI Clock Converter Core: The AXI Clock Converter Core is included in the Xilinx AXI Interconnect Core and is used to connect one AXI memory—mapped slave to another AXI memory—mapped master which is operating in a different clock domain. In the Packetizer Core, the AXI Clock Converter Core is used to operate the Register Space in the AXI4–Stream clock domain (s axis aclk).
- **AXI4–Lite Interface:** This module implements a 32–bit AXI4–Lite Slave Interface to access the Register Space. For additional details about the AXI4–Lite Interface, refer to Section 3.1 AXI4–Lite Core Interfaces.
- ☐ **Register Space:** This module contains the control and status registers including Interrupt Enable, Interrupt Flag and Interrupt Status registers. Registers are accessed through the AXI4–Lite interface.
- □ **AXI4–Stream Interfaces:** The Packetizer Core has two AXI4–Stream Interfaces. At the input, an AXI4–Stream Slave Interface is used to receive AXI4–Streams and at the output an AXI4–Stream Master Interface is used to transfer packed AXI4–Streams through the output ports. For more details about the AXI4–Stream Interfaces refer to Section 3.2 AXI4–Stream Core Interfaces.

#### **1.1** Functional Description (continued)

- ☐ Gate/ Trigger Generator Module: This module is used to generate an acquisition gate signal based on the selected mode.
- ☐ Trigger Control State Machine: This state machine is used generate packed output data streams based on the acquisition gate, and the values defined in the Mode Control Register. This state machine has three states:
  - **Reset** The Reset state resets the state machine based on the input reset signal (s\_axis\_aresetn) from the input AXI4–Stream Slave Interface.
  - Wait for Trigger Arm When the state machine is in the Wait for Arm state, it waits for the trigger arm signal, from the mode control register, to go High.
  - **Armed** Once in the Armed State, the core waits for the data acquisition gate signal to go High when a valid input is available on the input AXI4–Stream Slave Interface. When the acquisition gate signal goes High, output packed data streams are generated based on the data mode selected.

#### 1.2 Applications

The AXI4–Stream Data Flow Control and Packetizer 2 Core can be incorporated into any Kintex Ultrascale FPGA where data flow control and packetization of input AXI4–Stream is required.

## 1.3 System Requirements

For a list of system requirements, see the Vivado Design Suite Release Notes.

### 1.4 Licensing and Ordering Information

This core is included with all Pentek Navigator FPGA Design Kits for Pentek Jade series board products. Contact Pentek for Licensing and Ordering Information (www.pentek.com).

## 1.5 Contacting Technical Support

Technical Support for Pentek's Navigator FPGA Design Kits is available via e-mail (fpgasupport@pentek.com) or by phone (201–818–5900 ext. 238, 9 am to 5 pm EST).

#### 1.6 Documentation

This user manual is the main document for this IP core. The following documents provide supplemental material:

- 1) Vivado Design Suite User Guide: Designing with IP
- 2) Vivado Design Suite User Guide: Programming and Debugging
- 3) ARM AMBA AXI4 Protocol Version 2.0 Specification http://www.arm.com/products/system-ip/amba-specifications.php

## Chapter 2: General Product Specifications

#### 2.1 Standards

The AXI4–Stream Data Flow Control and Packetizer 2 Core has bus interfaces that comply with the *ARM AMBA AXI4–Lite Protocol Specification* and the *AMBA AXI4–Stream Protocol Specification*.

#### 2.2 Performance

The performance of the Packetizer Core is limited only by the FPGA logic speed. The values presented in this section should be used as an estimation guideline. Actual performance can vary.

#### 2.2.1 Maximum Frequencies

The Packetizer Core has two incoming clock signals. The AXI4–Stream clock has a maximum frequency of 350 MHz while the CSR clock across the AXI4–Lite interface has a maximum frequency of 250 MHz on a Kintex Ultrascale –2 speed grade FPGA. 250 MHz is typically the PCI Express (PCIe®) AXI bus clock frequency.

#### 2.3 Resource Utilization

The resource utilization of the Packetizer Core is shown in Table 2–1. Resources have been estimated for the Kintex Ultrascale XCKU060 –2 speed grade device. These values were generated using the Vivado Design Suite.

| Table 2–1: Resource Usage and Availability |        |  |  |  |  |
|--------------------------------------------|--------|--|--|--|--|
| Resource                                   | # Used |  |  |  |  |
| LUTs                                       | 771    |  |  |  |  |
| Flip-Flops                                 | 2328   |  |  |  |  |
| Memory LUTs                                | 41     |  |  |  |  |

**NOTE:** Actual utilization may vary based on the user design in which the Packetizer Core is incorporated.

## 2.4 Limitations and Unsupported Features

- ☐ This core supports only two samples—per—clock—cycle data streams.
- ☐ The input data streams must be either 32-bit real or 16-bit I/Q packed values.

### 2.5 Generic Parameters

This section is not applicable to this IP core.

## Chapter 3: Port Descriptions

This chapter provides details about the port descriptions for the following interface types:

- AXI4-Lite Core Interfaces
- AXI4–Stream Core Interfaces

#### 3.1 **AXI4-Lite Core Interfaces**

The AXI4–Stream Data Flow Control and Packetizer 2 Core uses the Control/Status Register (CSR) interface to control, and receive status from, the user design.

#### 3.1.1 Control/Status Register (CSR) Interface

The CSR interface is an AXI4–Lite Slave Interface that can be used to access the control and status registers in the Packetizer Core. Table 3–1 defines the ports in the CSR interface. See Chapter 4 for a Control/Status Register memory map and bit definitions. See the *AMBA AXI4–Lite Specification* for more details on operation of the AXI4–Lite interfaces.

| Table 3-1: Control/Status Register (CSR) Interface Port Descriptions |           |       |                                                                                                                                                                                                                                                                                                                                  |  |  |
|----------------------------------------------------------------------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Port                                                                 | Direction | Width | Description                                                                                                                                                                                                                                                                                                                      |  |  |
| s_axi_csr_aclk                                                       | Input     | 1     | Clock                                                                                                                                                                                                                                                                                                                            |  |  |
| s_axi_csr_aresetn                                                    | Input     | 1     | Reset: Active low. This signal will reset all control registers to their initial states.                                                                                                                                                                                                                                         |  |  |
| s_axi_csr_awaddr                                                     | Input     | 6     | Write Address: Address used for write operations. It must be valid when s_axi_csr_awvalid is asserted and must be held until s_axi_csr_awready is asserted by the Packetizer Core. Note that the Register Space registers occupy an address range of [Base Address + (0x00 to 0x3C)].                                            |  |  |
| s_axi_csr_awprot                                                     | Input     | 3     | Protection: The Packetizer Core ignores these bits.                                                                                                                                                                                                                                                                              |  |  |
| s_axi_csr_awvalid                                                    | Input     | 1     | Write Address Valid: This input must be asserted to indicate that a valid write address is available on s_axi_csr_awaddr. The Packetizer Core asserts s_axi_csr_awready when it is ready to accept the address. The s_axi_csr_awvalid must remain asserted until the rising clock edge after the assertion of s_axi_csr_awready. |  |  |

| Table 3-1: Cor    | Table 3-1: Control/Status Register (CSR) Interface Port Descriptions (Continued) |       |                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|-------------------|----------------------------------------------------------------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Port              | Direction                                                                        | Width | Description                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| s_axi_csr_awready | Output                                                                           | 1     | Write Address Ready: This output is asserted by the Packetizer Core when it is ready to accept the write address. The address is latched when s_axi_csr_awvalid and s_axi_csr_awready are high on the same cycle.                                                                                                                                   |  |  |  |
| s_axi_csr_wdata   | Input                                                                            | 32    | Write Data: This data will be written to the address specified by s_axi_csr_awaddr when s_axi_csr_wvalid and s_axi_csr_wready are both asserted. The value must be valid when s_axi_csr_wvalid is asserted and held until s_axi_csr_wready is also asserted.                                                                                        |  |  |  |
| s_axi_csr_wstrb   | Input                                                                            | 4     | Write Strobes: This signal, when asserted, indicates the number of bytes of valid data on the s_axi_csr_wdata signal. Each of these bits, when asserted, indicate that the corresponding byte of s_axi_csr_wdata contains valid data. Bit 0 corresponds to the least significant byte, and bit 3 to the most significant.                           |  |  |  |
| s_axi_csr_wvalid  | Input                                                                            | 1     | Write Valid: This signal must be asserted to indicate that the write data is valid for a write operation. The value on s_axi_csr_wdata is written into the register at address s_axi_csr_awaddr when s_axi_csr_wready and s_axi_csr_wvalid are high on the same cycle.                                                                              |  |  |  |
| s_axi_csr_wready  | Output                                                                           | 1     | Write Ready: This signal is asserted by the Packetizer Core when it is ready to accept data. The value on s_axi_csr_wdata is written into the register at address s_axi_csr_awaddr when s_axi_csr_wready and s_axi_csr_wvalid are high on the same cycle, assuming that the address has already or simultaneously been submitted.                   |  |  |  |
| s_axi_csr_bresp   | Output                                                                           | 2     | Write Response: The Packetizer Core indicates success or failure of a write transaction through this signal, which is valid when s_axi_csr_bvalid is asserted;  00 = Success of normal access  01 = Success of exclusive access  10 = Slave Error  11 = Decode Error  Note: For more details about this signal refer to the AMBA AXI Specification. |  |  |  |
| s_axi_csr_bready  | Input                                                                            | 1     | Write Response Ready: This signal must be asserted by the user logic when it is ready to accept the Write Response.                                                                                                                                                                                                                                 |  |  |  |
| s_axi_csr_bvalid  | Output                                                                           | 1     | Write Response Valid: This signal is asserted by the Packetizer Core when the write operation is complete and the Write Response is valid. It is held until s_axi_csr_bready is asserted by the user logic.                                                                                                                                         |  |  |  |

| Table 3-1: Control/Status Register (CSR) Interface Port Descriptions (Continued) |           |       |                                                                                                                                                                                                                                                                                                                                                   |  |  |
|----------------------------------------------------------------------------------|-----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Port                                                                             | Direction | Width | Description                                                                                                                                                                                                                                                                                                                                       |  |  |
| s_axi_csr_araddr                                                                 | Input     | 6     | <b>Read Address:</b> Address used for read operations. It must be valid when <b>s_axi_csr_arvalid</b> is asserted and must be held until <b>s_axi_csr_arready</b> is asserted by the Packetizer Core.                                                                                                                                             |  |  |
| s_axi_csr_arprot                                                                 | Input     | 3     | Protection: These bits are ignored by the Packetizer Core                                                                                                                                                                                                                                                                                         |  |  |
| s_axi_csr_arvalid                                                                | Input     | 1     | Read Address Valid: This input must be asserted to indicate that a valid read address is available on the s_axi_csr_araddr. The Packetizer Core asserts s_axi_csr_arready when it ready to accept the Read Address. This input must remain asserted until the rising clock edge after the assertion of s_axi_csr_arready.                         |  |  |
| s_axi_csr_arready                                                                | Output    | 1     | Read Address Ready: This output is asserted by the Packetizer Core when it is ready to accept the read address. The address is latched when s_axi_csr_arvalid and s_axi_csr_arready are high on the same cycle.                                                                                                                                   |  |  |
| s_axi_csr_rdata                                                                  | Output    | 32    | <b>Read Data:</b> This value is the data read from the address specified by the <b>s_axi_csr_araddr</b> when <b>s_axi_csr_arvalid</b> and <b>s_axi_csr_arready</b> are high on the same cycle.                                                                                                                                                    |  |  |
| s_axi_csr_rresp                                                                  | Output    | 2     | Read Response: The Packetizer Core indicates success or failure of a read transaction through this signal, which is valid when s_axi_csr_rvalid is asserted;  00 = Success of normal access  01 = Success of exclusive access  10 = Slave Error  11 = Decode Error  Note: For more details about this signal refer to the AMBA AXI Specification. |  |  |
| s_axi_csr_rvalid                                                                 | Output    | 1     | Read Data Valid: This signal is asserted by the Packetizer Core when the read is complete and the read data is available on s_axi_csr_rdata. It is held until s_axi_csr_ready is asserted by the user logic.                                                                                                                                      |  |  |
| s_axi_csr_rready                                                                 | Input     | 1     | <b>Read Data Ready:</b> This signal is asserted by the user logic when it is ready to accept the Read Data.                                                                                                                                                                                                                                       |  |  |
| irq                                                                              | Output    | 1     | Interrupt: This is an active high, edge-type interrupt output.                                                                                                                                                                                                                                                                                    |  |  |

#### 3.2 AXI4-Stream Core Interfaces

The Packetizer Core has the following AXI4–Stream Interfaces, used to receive and transfer data streams.

- Combined Sample Data/ Timestamp/ Information Stream (PDTI) Interface: This is an AXI4-Stream Slave Interface of the core used to receive AXI4-Streams in the PDTI format.
- Packetized Sample Data/ Timestamp/ Information Stream (PPKT) Interface: This is an AXI4-Stream Master Interface of the core used to transfer packed AXI4-Streams in the PPKT format.

## 3.2.1 Combined Sample Data/ Timestamp/ Information Streams (PDTI) Interface

The Pentek Jade series board products have AXI4–Streams that follow a combined Sample Data/ Timestamp/ Information Stream (PDTI) format. This type of data stream combines sample data with its time–aligned timestamp and data information. There is an AXI4–Stream Slave Interface across the input to receive AXI4–Streams in the PDTI format. Table 3–2 defines the ports in the AXI4–Stream Slave Combined Sample Data/ Timestamp/ Information Stream Interface. See the *AMBA AXI4–Stream Specification* for more details on the operation of the AXI4–Stream Interface.

| Table 3-2: Combined Sample Data/ Timestamp/ Information Streams Interface Port Descriptions |           |       |                                                                                                                                                                                                                                                                                    |  |  |  |
|---------------------------------------------------------------------------------------------|-----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Port                                                                                        | Direction | Width | Description                                                                                                                                                                                                                                                                        |  |  |  |
| s_axis_aclk                                                                                 | Input     | 1     | AXI4-Stream Clock                                                                                                                                                                                                                                                                  |  |  |  |
| s_axis_aresetn                                                                              | Input     | 1     | Reset: Active Low.                                                                                                                                                                                                                                                                 |  |  |  |
| s_axis_pdti_tdata                                                                           | Input     | 32    | Input Data: This is the input data stream.  tdata[31:0] = Real value [31:0] when data type – Real tdata[15:0] = Real Sample (+) tdata[31:16] = Real Sample (++1) tdata[31:0] = Packed I/Q data – I [15:0], Q [31:16] tdata[31:0] = I or Q data when data is in unpacked I/Q format |  |  |  |

| Table                  | Table 3-2: Combined Sample Data/ Timestamp/ Information Streams Interface Port Descriptions (Continued) |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|------------------------|---------------------------------------------------------------------------------------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Port                   | Direction                                                                                               | Width | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
| s_axis_pdti_tvali<br>d | Input                                                                                                   | 1     | Input Data Valid: Asserted when data is valid on s_axis_pdti_tdata.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| s_axis_pdti_tuser      | Input                                                                                                   | 128   | Sideband Information: This is the user-defined sideband information received alongside the data stream. tuser [63:0] - Timestamp[63:0] tuser [71:64] - Gate Positions When 2 Real Samples/clkcycle: tuser [64] = Gate Level associated with sample (+) tuser [65] = Gate Level associated with sample (++1) When Complex Samples: tuser [64] = Gate tuser [65] = '0' or unused tuser [79:72] - Sync Positions When 2 Real Samples/clkcycle: tuser [72] = Sync Level associated with sample (+) tuser [73] = Sync Level associated with sample (++1) When Complex Samples: tuser [72] = Sync tuser [72] = Sync tuser [73] = '0' or unused tuser [87:80] - PPS Positions When 2 Real Samples/clkcycle: tuser [80] = PPS Level associated with sample (+) tuser [81] = '0' or unused tuser [92] - I/Q data of the sample => 0 = I; 1 = Q tuser [94:93] - Data Format => 0 = 8-bit; 1 = 16-bit; 2 = 24-bit; 3 = 32-bit tuser [95] - Data Type => 0 = Real; 1 = I/Q tuser [103:96] - channel [7:0] tuser [127:104] - Reserved Note: The bits [103:96] define the channel number in the user design from where the data is being received. |  |  |  |  |

#### 3.2 **AXI4-Stream Core Interfaces (continued)**

## 3.2.2 Packetized Sample Data/ Timestamp/ Information Streams (PPKT) Interface

The Pentek Jade series board products have packed AXI4–Streams that follow a Packetized Sample Data/ Timestamp/ Information Stream (PPKT) format. This type of data stream contains packed sample data streams used as input to DMAs. The start of packet (SOP) and **tlast** signals are used to mark the start and end of gate acquisition data. There is an AXI4–Stream Master Interface across the output to transfer AXI4–Streams in the PPKT format. Table 3–3 defines the ports in the AXI4–Stream Master Packetized Sample Data/ Time–stamp/ Information Stream Interface. See the *AMBA AXI4–Stream Specification* for more details on the operation of the AXI4–Stream Interface.

| Table 3-           | Table 3–3: Packetized Sample Data/ Timestamp/ Information Streams Interface Port Descriptions |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
|--------------------|-----------------------------------------------------------------------------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Port               | Direction                                                                                     | Width | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| m_axis_ppkt_tdata  | Output                                                                                        | 32    | Output Data: This is the output packed data stream. The packaged data format varies for Real and I/Q data types.  Real Data: Real data with two samples stored in each 32—bit output data word.  First sample is placed into bits 15:0  Second sample is placed into bits 31:16  I/Q Packed Data: I/Q packed data is packed with each sample from the input data placed in each 32—bit output data word.  m_axis_pppkt_tdata(15:0) - I  m_axis_ppkt_tdata (31:16) - Q  Unpacked I/Q Data: In the unpacked I/Q data mode, the data is output in two consecutive 32 bits on the m_axis_ppkt_data bus for I and Q data of each sample. If complex data is 24—bit, it is left justified in 32—bit field. |  |  |  |  |
| m_axis_ppkt_tvalid | Output                                                                                        | 1     | Input Data Valid: Asserted when data is valid on m_axis_ppkt_tdata.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |

| Table 3-          |           | -     | le Data/ Timestamp/ Information Streams<br>t Descriptions (Continued)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------|-----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port              | Direction | Width | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| m_axis_ppkt_tuser | Output    | 80    | Sideband Information: This is the user-defined sideband information transmitted alongside the data stream. tuser [63:0] - Timestamp[63:0] tuser [64] - Start of Packet (SOP) SOP marks the beginning of the acquisition by the selected gate or trigger. tuser [66:65] - Data Format => 0 = 8-bit; 1 = 16-bit; 2 = 24-bit; 3 = 32-bit tuser [67] - Data Type => 0 = Real; 1 = I/Q tuser [75:68] - channel [7:0] tuser [79:76] - user defined data[3:0] (Considered valid on tlast only)  Note: The bits [75:68] define the channel number in the user design from where the data is being received. |
| m_axis_ppkt_tkeep | Output    | 2     | Data Keep: The tkeep signal indicates the valid data sample bytes on m_axis_ppkt_tdata. Each bit corresponds to a 16-bit word in m_axis_ppkt_tdata i.e., bit 0 corresponds to the least significant 16 bits and bit 1 to the most significant. When it is asserted, the data is considered valid. All tkeep bits must be '1' contiguously until the tlast. Tkeep is only considered valid when tlast is asserted.                                                                                                                                                                                   |
| m_axis_ppkt_tlast | Output    | 1     | Data Last: When asserted, this marks the last data in the current data frame. This marks the last data sample in the acquisition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| /\/\/\frac{1}{2} = ;             \ | AXI4-Stream | Data Flow | Control and | Packetizer | 2 IP |
|------------------------------------|-------------|-----------|-------------|------------|------|
|------------------------------------|-------------|-----------|-------------|------------|------|

Page 22

This page is intentionally blank

## Chapter 4: Register Space

This chapter provides the memory map and register descriptions for the register space of the AXI4–Stream Data Flow Control and Packetizer 2 Core. The memory map is provided in Table 4–1.

|                         | Table 4-1: Registe          | er Space M | lemory Map                                                                                                              |
|-------------------------|-----------------------------|------------|-------------------------------------------------------------------------------------------------------------------------|
| Register Name           | Address<br>(Base Address +) | Access     | Description                                                                                                             |
| Mode Control            | 0x00                        | R/W        | Controls the mode select, data mode select, and state machine trigger arm signals                                       |
| Trigger Clear           | 0x04                        | R/W        | Controls the clear and disarm signals of the Trigger Control State Machine                                              |
| Trigger Delay Value     | 0x08                        | R/W        | Controls the Trigger Delay value in Trigger mode                                                                        |
| Trigger Length Value    | 0x0C                        | R/W        | Controls the Trigger Length value in Trigger mode                                                                       |
| Timestamp Start (Lower) | 0x10                        | R/W        | Controls the lower dword (32 bits) of the start of timestamp range in Timestamp mode                                    |
| Timestamp Start (Upper) | 0x14                        | R/W        | Controls the upper dword of the start of timestamp range in Timestamp mode                                              |
| Timestamp End (Lower)   | 0x18                        | R/W        | Controls the lower dword of the end of timestamp range in Timestamp mode                                                |
| Timestamp End (Upper)   | 0x1C                        | R/W        | Controls the upper dword of the end of timestamp range in Timestamp mode                                                |
| Status                  | 0x20                        | R          | Indicates status of the Trigger Control<br>State Machine, the mode of operation of<br>the core, and the input data type |
| Interrupt Enable        | 0x34                        | R/W        | Interrupt enable bits                                                                                                   |
| Interrupt Status        | 0x38                        | R          | Interrupt source status bits                                                                                            |
| Interrupt Flag          | 0x3C                        | R/Clr      | Interrupt flag bits                                                                                                     |

## 4.1 Mode Control Register

This register controls the trigger arm and stay armed control signals of the trigger control state machine. It is also used to control the mode of operation of the Packetizer Core, and the data mode of the input. The Mode Control Register is illustrated in Figure 4–1 and described in Table 4–2.

Figure 4-1: Mode Control Register



.

|      | Table 4         | –2: Mod          | e Contro       | Register (Base Address + 0x00)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|-----------------|------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits | Field Name      | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:8 | Reserved        | N/A              | N/A            | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 7    | local_gate      | 0                | R/W            | Local Gate: This is the user-defined local gate, which is used as the data acquisition gate signal source when the local gate mode is enabled.  0 = Inactive 1 = Active                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 6    | local_gate_mode | 0                | R/W            | Local Gate Mode Enable: This bit is used to enable/ disable local gate mode. When the Packetizer Core is operating in Gate mode (mode_sel = 00) with local gate mode enabled, the user-defined local gate (bit 7) becomes the source of the data acquisition gate signal generated by the core. It can also be used as a local trigger source if the mode is trigger mode or trigger hold mode.  0 = Disable 1 = Enable                                                                                                                                                                                             |
| 5:4  | data_mode_sel   | 0                | R/W            | Data Mode Select: These bits are used to select the data type of the input data to the Packetizer Core. For detailed description of output data in each mode, refer to Table 3–3.  00 = Real Data (two packed samples) 01 = Packed I/Q Data -In a 32-bit word -                                                                                                                                                                                                                                                                                                                                                     |
| 3:2  | mode_sel        | 00               | R/W            | Mode Select: These bits are used to select the mode of operation of the Packetizer Core. They define the source of the data acquisition gate signal generated by the core.  00 = Gate mode => Input gate signal is the source 01 = Trigger mode => Input gate signal as trigger to generate acquisition gate of user-defined trigger length and trigger delay 10 = Trigger Hold mode => Input gate signal as trigger to generate acquisition gate which remains active until the trigger control state machine is reset 11 = Timestamp mode => Acquisition gate signal for the desired timestamp range is generated |

|      | Table 4-2: Mode Control Register (Base Address + 0x00) (Continued) |                  |                |                                                                                                                                                                                 |  |  |  |
|------|--------------------------------------------------------------------|------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bits | Field Name                                                         | Default<br>Value | Access<br>Type | Description                                                                                                                                                                     |  |  |  |
| 1    | stay_armed                                                         | 0                | R/W            | Stay Armed: This bit is used to keep the trigger control state machine in the armed state.  0 = Returns to disarmed state after one gate or trigger  1 = Remains in armed state |  |  |  |
| 0    | trig_arm                                                           | 0                | R/W            | Trigger Arm: This bit is used to arm the trigger control state machine.  0 = No action  1 = Toggling from '0' to '1' back to '0' changes state to armed state.                  |  |  |  |

NOTE: Data Mode, Select, and Mode Select values only take effect at the time of arming the state machine. Therefore they should be set to desired values prior to arming. Changes after arming have no effect until it is disarmed and armed again. The Status Register indicates the actual settings being used by the state machine.

## 4.2 Trigger Clear Register

This register is used to enable (or disable) a clear (reset) of the trigger control state machine from any state to the Reset state. It is also used to control disarming of the state machine to the Reset State after the acquisition gate ends. This register is illustrated in Figure 4–2 and described in Table 4–3.

Figure 4-2: Trigger Clear Register



|      | Table 4-3: Trigger Clear Register (Base Address + 0x04) |               |                |                                                                                                                                                                   |  |  |  |
|------|---------------------------------------------------------|---------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bits | Field Name                                              | Default Value | Access<br>Type | Description                                                                                                                                                       |  |  |  |
| 31:2 | Reserved                                                | N/A           | N/A            | Reserved                                                                                                                                                          |  |  |  |
| 1    | disarm                                                  | 0             | R/W            | Disarm: This bit is used to disarm the state machine from armed state to the reset state if it is armed.  0 = No action 1 = Toggle from '0' to '1' to'0' disarms. |  |  |  |
| 0    | trig_clear                                              | 0             | R/W            | Trigger Clear: This bit used to clear the trigger control state machine from any state to the reset state.  0 = No action 1 = Trigger clear                       |  |  |  |

## 4.3 Trigger Delay Value Register

When the Packetizer Core is operating in Trigger mode, the input gate signal is treated as a trigger to generate the data acquisition gate signal. The acquisition gate signal is delayed from the trigger event by a delay value defined by the Trigger Delay Value Register. This register is illustrated in Figure 4–3 and described in Table 4–4.

Figure 4-3: Trigger Delay Value Register



|      | Table 4-4: Trigger Delay Value Register (Base Address + 0x08) |               |                |                                                                                                                                                                                                                                                     |  |  |  |
|------|---------------------------------------------------------------|---------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bits | Field Name                                                    | Default Value | Access<br>Type | Description                                                                                                                                                                                                                                         |  |  |  |
| 31:0 | trig_dly                                                      | 0x00000000    | R/W            | Trigger Delay Value: This is the delay to be introduced to the data acquisition gate signal after a trigger event has occurred when the Packetizer Core is operating in Trigger mode. Note: This is a delay of clock cycles. It can be set to zero. |  |  |  |

## 4.4 Trigger Length Value Register

When the Packetizer Core is operating in the Trigger mode, the input gate signal is treated as a trigger to generate the data acquisition gate signal. The Trigger Length Value Register is used to control the active gate length of the data acquisition gate signal. This register is illustrated in

Figure 4–4 and described in Table 4–5.

Figure 4-4: Trigger Length Value Register



|      | Table 4–5: Trigger Length Value Register (Base Address + 0x0C) |               |                |                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|------|----------------------------------------------------------------|---------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bits | Field Name                                                     | Default Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| 31:0 | trig_len                                                       | 0x0000010     | R/W            | Trigger Length Value: This is the length of the data acquisition gate signal generated by the gate/trigger generator module when the Packetizer Core is operating in Trigger mode. This value is in terms of data samples. For real data, there are two data samples per clock cycle. For complex data, there is one sample per clock cycle. The value entered for trig-len should be one less than the desired number of samples. |  |  |  |

## 4.5 Timestamp Start (Lower) Register

This register controls the lower dword (least significant 32 bits) of the start value of time–stamp range when the core is operating in Timestamp mode. This register is illustrated in Figure 4–5 and described in Table 4–6.

Figure 4-5: Timestamp Start (Lower) Register



|      | Table 4-6: Timestamp Start (Lower) Register (Base Address + 0x10) |               |                |                                                                                                                            |  |  |  |
|------|-------------------------------------------------------------------|---------------|----------------|----------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bits | Field Name                                                        | Default Value | Access<br>Type | Description                                                                                                                |  |  |  |
| 31:0 | start_ts_ldw                                                      | 0x00000000    | R/W            | Timestamp Start Lower DWord: These bits define the lower dword of the start value of the timestamp in the timestamp range. |  |  |  |

## 4.6 Timestamp Start (Upper) Register

This register controls the upper dword (most significant 32 bits) of the start value of the timestamp range when the core is operating in Timestamp mode. This register is illustrated in Figure 4–6 and described in Table 4–7.

Figure 4-6: Timestamp Start (Upper) Register



|      | Table 4–7: Timestamp Start (Upper) Register (Base Address + 0x14) |               |                |                                                                                                                            |  |  |  |
|------|-------------------------------------------------------------------|---------------|----------------|----------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bits | Field Name                                                        | Default Value | Access<br>Type | Description                                                                                                                |  |  |  |
| 31:0 | start_ts_udw                                                      | 0x00000000    | R/W            | Timestamp Start Upper DWord: These bits define the upper dword of the start value of the timestamp in the timestamp range. |  |  |  |

## 4.7 Timestamp End (Lower) Register

This register controls the lower dword (least significant 32 bits) of the end value of the timestamp range when the core is operating in Timestamp mode. This register is illustrated in Figure 4–7 and described in Table 4–8.

Figure 4–7: Timestamp End (Lower) Register



|      | Table 4–8: Timestamp End (Lower) Register (Base Address + 0x18) |               |                |                                                                                                                        |  |  |  |
|------|-----------------------------------------------------------------|---------------|----------------|------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bits | Field Name                                                      | Default Value | Access<br>Type | Description                                                                                                            |  |  |  |
| 31:0 | end_ts_ldw                                                      | 0x0000010     | R/W            | Timestamp End Lower DWord: These bits define the lower dword of the end value of the timestamp in the timestamp range. |  |  |  |

## 4.8 Timestamp End (Upper) Register

This register controls the lower dword (most significant 32 bits) of the end value of the timestamp range when the core is operating in Timestamp mode. This register is illustrated in Figure 4–6 and described in Table 4–7.

Figure 4-8: Timestamp End (Upper) Register



| Table 4–9: Timestamp End (Upper) Register (Base Address + 0x1C) |            |               |                |                                                                                                                        |  |  |
|-----------------------------------------------------------------|------------|---------------|----------------|------------------------------------------------------------------------------------------------------------------------|--|--|
| Bits                                                            | Field Name | Default Value | Access<br>Type | Description                                                                                                            |  |  |
| 31:0                                                            | end_ts_ldw | 0x00000000    | R/W            | Timestamp End Upper DWord: These bits define the upper dword of the end value of the timestamp in the timestamp range. |  |  |

## 4.9 Status Register

The Status Register indicates the mode of operation of the core, data mode selected, and the status of the trigger control state machine. This register is illustrated in Figure 4–9 and described in Table 4–10.

Figure 4–9: Status Register



| Table 4–10: Status Register (Base Address + 0x20) |                          |     |                |                                                                                                                                                                                               |  |
|---------------------------------------------------|--------------------------|-----|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bits                                              | Field Name Default Value |     | Access<br>Type | Description                                                                                                                                                                                   |  |
| 31:7                                              | Reserved                 | N/A | N/A            | Reserved                                                                                                                                                                                      |  |
| 6:5                                               | data_mode_sel            | 00  | R              | Data Mode Selected: These bits indicates the data mode selected.  00 = Packed Real Data 01 = Packed I/Q Data 10 = Reserved 11 = Unpacked I/Q Data                                             |  |
| 4:3                                               | mode_sel                 | 00  | R              | Mode Selected: These bits indicate the selected mode of operation of the core.  00 = Gate mode 01 = Trigger mode 10 = Trigger Hold mode 11 = Timestamp mode                                   |  |
| 2                                                 | active                   | 0   | R              | Active: This bit indicates that data acquisition and packing is in progress in the trigger control state machine.  0 = data acquisition inactive 1 = data acquisition in progress             |  |
| 1                                                 | armed                    | 0   | R              | Armed: This bit indicates that the trigger control state machine is in the armed state.  0 = state machine not in armed state  1 = state machine in armed state                               |  |
| 0                                                 | waiting_arm              | 0   | R              | Waiting for Arm: This bit indicates that the trigger control state machine is in the wait for arm state.  0 = state machine not in wait for arm state 1 = state machine in wait for arm state |  |

**NOTE:** You should read the status register after setup and arming to verify the settings.

### 4.10 Interrupt Enable Register

The bits in the interrupt enable register are used to enable (or disable) the generation of interrupts based on the condition of certain circuit elements, known as interrupt sources. When a bit in this register associated with a given interrupt source is High, an interrupt will be generated by the rising edge of that source's Interrupt Status Register bit (See Section 4.11). This register is illustrated in Figure 4–10 and described in Table 4–11.

Figure 4-10: Interrupt Enable Register



|      | Table 4-11: Interrupt Enable Register (Base Address + 0x34) |                  |                |                                                                                                                                                                                                                                                                                     |  |
|------|-------------------------------------------------------------|------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bits | Field Name                                                  | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                         |  |
| 31:5 | Reserved                                                    | N/A              | N/A            | Reserved                                                                                                                                                                                                                                                                            |  |
| 4    | bad_trigger                                                 | 0                | R/W            | Bad Trigger: This bit enables or disables the bad trigger interrupt source. The bad trigger interrupt source indicates that a trigger has been generated before the completion of the last trigger period.  0 = Disable interrupt 1 = Enable interrupt                              |  |
| 3    | armed_re                                                    | 0                | R/W            | Armed Rising Edge: This bit enables or disables the armed rising edge interrupt source. The armed rising edge interrupt source indicates a rising edge on the armed status signal of the status register.  0 = Disable interrupt 1 = Enable interrupt                               |  |
| 2    | waiting_arm_re                                              | 0                | R/W            | Waiting for Arm Rising Edge: This bit enables or disables the wait for arm rising edge interrupt source. The wait for arm rising edge interrupt source indicates a rising edge on the waiting_arm status signal of the status register.  0 = Disable interrupt 1 = Enable interrupt |  |

| Table 4–11: Interrupt Enable Register (Base Address + 0x34) (Continued) |            |                  |                |                                                                                                                                                                                                                                                                    |
|-------------------------------------------------------------------------|------------|------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits                                                                    | Field Name | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                        |
| 1                                                                       | acq_end    | 0                | R/W            | End of Acquisition: This bit enables or disables the end of acquisition interrupt source. The end of acquisition interrupt source indicates the end of data acquisition in the trigger control state machine.  0 = Disable interrupt  1 = Enable interrupt         |
| 0                                                                       | acq_start  | 0                | R/W            | Start of Acquisition: This bit enables or disables the start of acquisition interrupt source. The start of acquisition interrupt source indicates the start of data acquisition in the trigger control state machine.  0 = Disable interrupt  1 = Enable interrupt |

## 4.11 Interrupt Status Register

The Interrupt Status Register has read—only access associated with each interrupt condition. A status bit changes to '1' when the source interrupt occurs. When a status bit in this register changes to '1' the corresponding flag bit in the Interrupt Flag Register is set to '1'. A status bit in this register clears to '0' when that interrupt condition clears, whereas the associated flag bit in the Interrupt Flag Register remains at logic '1' until it is explicitly cleared by the user.

Some of the interrupt sources are transient and so may not appear in the Interrupt Status Register at the time it is read. In such cases, use the Interrupt Flag Register to see the interrupt conditions that have occurred. The Interrupt Status Register is illustrated in Figure 4–11 and described in Table 4–12.

Figure 4–11: Interrupt Status Register



|                                           | Table 4–12: Interrupt Status Register (Base Address + 0x38) |     |     |                                                                                                                                                                                                                                                                  |  |  |  |
|-------------------------------------------|-------------------------------------------------------------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bits Field Name Default Access Value Type |                                                             |     |     | Description                                                                                                                                                                                                                                                      |  |  |  |
| 31:5                                      | Reserved                                                    | N/A | N/A | Reserved                                                                                                                                                                                                                                                         |  |  |  |
| 4                                         | bad_trigger                                                 | 0   | R/W | Bad Trigger: This bit enables or disables the bad trigger interrupt source. The bad trigger interrupt source indicates that a trigger has been generated before the completion of the last trigger period.  0 = Disable interrupt  1 = Enable interrupt          |  |  |  |
| 3                                         | armed_re                                                    | 0   | R   | Armed Rising Edge: This bit indicates the status of the armed rising edge interrupt source. The armed rising edge interrupt source indicates a rising edge on the armed status signal of the status register.  0 = No interrupt 1 = Interrupt condition asserted |  |  |  |

|      | Table 4–12: Interrupt Status Register (Base Address + 0x38) (Continued) |   |                |                                                                                                                                                                                                                                                                                                |  |  |  |  |
|------|-------------------------------------------------------------------------|---|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bits | Bits Field Name D                                                       |   | Access<br>Type | Description                                                                                                                                                                                                                                                                                    |  |  |  |  |
| 2    | waiting_arm_re                                                          | 0 | R              | Waiting for Arm Rising Edge: This bit indicates the status of the wait for arm rising edge interrupt source. The wait for arm rising edge interrupt source indicates a rising edge on the waiting_arm status signal of the status register.  0 = No interrupt 1 = Interrupt condition asserted |  |  |  |  |
| 1    | acq_end                                                                 | 0 | R              | End of Acquisition: This bit indicates the status of the end of acquisition interrupt source. The end of acquisition interrupt source indicates the end of data acquisition in the trigger control state machine.  0 = No interrupt  1 = Interrupt condition asserted                          |  |  |  |  |
| 0    | acq_start                                                               | 0 | R              | Start of Acquisition: This bit indicates the status of the start of acquisition interrupt source. The start of acquisition interrupt source indicates the start of data acquisition in the trigger control state machine.  0 = No interrupt  1 = Interrupt condition asserted                  |  |  |  |  |

## 4.12 Interrupt Flag Register

The Interrupt Flag Register has read/clear access associated with each interrupt condition. When reset, this register has all bits set to '0' (cleared). Each flag bit in this register latches an interrupt occurrence. A '1' in any flag bit in this register indicates that an interrupt has occurred.

Note that when any status bit in the Interrupt Status Register, changes to '1' the corresponding flag bit in this register will also be set to '1'. However, when a status bit in the Interrupt Status Register clears from '1' to '0', the corresponding latched flag bit in this register does not clear, but remains at '1'. To clear the flag bits, write '1's to the desired bits. The flags are not affected by the Interrupt Enable Register. The Interrupt Flag Register is illustrated in Figure 4–12 and described in Table 4–13.

Figure 4-12: Interrupt Flag Register



|                                           | Table 4–13: Interrupt Flag Register (Base Address + 0x3C) |     |       |                                                                                                                                                                                                                                                                     |  |  |  |  |
|-------------------------------------------|-----------------------------------------------------------|-----|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bits Field Name Default Access Value Type |                                                           |     |       | Description                                                                                                                                                                                                                                                         |  |  |  |  |
| 31:5                                      | Reserved                                                  | N/A | N/A   | Reserved                                                                                                                                                                                                                                                            |  |  |  |  |
| 4                                         | bad_trigger                                               | 0   | R/W   | Bad Trigger: This bit enables or disables the bad trigger interrupt source. The bad trigger interrupt source indicates that a trigger has been generated before the completion of the last trigger period.  0 = Disable interrupt  1 = Enable interrupt             |  |  |  |  |
| 3                                         | armed_re                                                  | 0   | R/Clr | Armed Rising Edge: This bit indicates the armed rising edge interrupt flag. The armed rising edge interrupt source indicates a rising edge on the armed status signal of the status register.  Read:  0 = No interrupt 1 = Interrupt latched Clear: 1 = Clear latch |  |  |  |  |

| Table 4–13: Interrupt Flag Register (Base Address + 0x3C) (Continued) |                |                  |                |                                                                                                                                                                                                                                                                                                   |  |  |  |
|-----------------------------------------------------------------------|----------------|------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bits                                                                  | Field Name     | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                       |  |  |  |
| 2                                                                     | waiting_arm_re | 0                | R/Clr          | Waiting for Arm Rising Edge: This bit indicates the wait for arm rising edge interrupt flag. The wait for arm rising edge interrupt source indicates a rising edge on the waiting_arm status signal of the status register.  Read:  0 = No interrupt 1 = Interrupt latched Clear: 1 = Clear latch |  |  |  |
| 1                                                                     | acq_end        | 0                | R/Clr          | End of Acquisition: This bit indicates the end of acquisition interrupt flag. The end of acquisition interrupt source indicates the end of data acquisition in the trigger control state machine.  Read:  0 = No interrupt  1 = Interrupt latched  Clear: 1 = Clear latch                         |  |  |  |
| 0                                                                     | acq_start      | 0                | R/Clr          | Start of Acquisition: This bit indicates the start of acquisition interrupt flag. The start of acquisition interrupt source indicates the start of data acquisition in the trigger control state machine.  Read:  0 = No interrupt  1 = Interrupt latched  Clear: 1 = Clear latch                 |  |  |  |

# Chapter 5: Designing with the Core

This chapter includes guidelines and additional information to facilitate designing with the AXI4–Stream Data Flow Control and Packetizer 2 Core.

## 5.1 General Design Guidelines

The AXI4–Stream Data Flow Control and Packetizer 2 Core provides the required logic to control the input data flow and generate packed output data streams. This IP core supports AXI4–Lite and AXI4–Stream user interfaces. The user can control the Gate/Trigger Generator Module and the Trigger Control State Machine to generate the desired output by setting the required values of the control registers as described in Chapter 4.

## 5.2 Clocking

AXI4-Stream Clock: s\_axis\_aclk

This clock is used to clock all ports in the Packetizer Core except the CSR port.

CSR Clock: s axi csr aclk

This clock is the input AXI4–Lite Interface clock to the core.

### 5.3 Resets

Main reset: s\_axis\_aresetn

This is an active low synchronous reset associated with **s\_axis\_aclk**. It has no effect on control registers.

CSR Reset: s axi csr aresetn

This is an active low reset synchronous with **s\_axi\_csr\_clk**. When asserted, the control/status registers and the interrupt registers are reset.

## 5.4 Interrupts

This core has an edge-type (rising edge-triggered) interrupt output. It is synchronous with the **s\_axis\_aclk**. On the rising edge of any interrupt signal, a one-clock-cycle-wide pulse is output from the core on it **irq** output. Each interrupt event is stored in two registers, accessible on the **s axi csr** bus.

## 5.4 Interrupts (continued)

The Interrupt Status Register always reflects the current state of the interrupt condition, which may have changed since the generation of the interrupt. The Interrupt Flag Register latches the occurrence of each interrupt, in a bit that retains its state until explicitly cleared. The Interrupt flags can be cleared by writing '1' to the associated bit's location. All interrupt sources that are enabled (via the Interrupt Enable Register) are "OR ed" onto the **irq** output.

**NOTE:** All interrupt sources are latched in the interrupt flag register, even when an interrupt source is not enabled to create an interrupt.

NOTE: Because this core uses edge—triggered interrupts, the fact that an interrupt condition may remain active after servicing will not cause the generation of a new interrupt. A new interrupt will only be generated by another rising edge on an interrupt source.

## 5.5 Interface Operation

**CSR Interface:** This is the Control/Status Register Interface and is associated with **s\_axis\_aclk**. It is a standard AXI4–Lite Slave Interface. See Chapter 4 for the control register memory map, which provides more details on the registers that can be accessed through this interface.

Combined Sample Data/ Timestamp/ Information Streams (PDTI) Interface: This core implements an AXI4–Stream Slave interface across the input to receive AXI PDTI streams and is associated with **s\_axis\_aclk**. For more details about this interface, refer to Section 3.2.1.

Packetized Sample Data/ Timestamp/ Information Streams (PPKT) Interface: This core implements an AXI4–Stream Master interface across the output to transfer AXI PPKT streams and is associated with s\_axis\_aclk. For more details about this interface, refer to Section 3.2.2.

## 5.6 Timing Diagrams

The timing diagram for the Packetizer Core is shown in Figure 6–3. This timing diagram is obtained by running the simulation of the test bench of the core in Vivado VSim environment. For more details about the test bench, refer to Section 6.5.

# 5.7 Programming Sequence Diagram



| AXI4-Stream                           | Data  | F1070               | Control                 | and   | Packetizes          | r 2        | ΙP  |
|---------------------------------------|-------|---------------------|-------------------------|-------|---------------------|------------|-----|
| $\Delta \Delta 14 - 311 \epsilon u m$ | 1/414 | $\Gamma L U \omega$ | $\mathbf{L}$ . $OHLIOL$ | u n u | F U.C.N.P.I.I.Z.P.I | <i>Z</i> . | 1 1 |

Page 44

This page is intentionally blank

# Chapter 6: Design Flow Steps

## 6.1 Pentek IP Catalog

This chapter describes customization and generation of the Pentek AXI4–Stream Data Flow Control and Packetizer 2 Core. It also includes simulation, synthesis, and implementation steps that are specific to this IP core. This core can be generated from the Vivado IP Catalog when the Pentek IP Repository has been installed. It will appear in the IP Catalog list as px\_axis\_pdti2ppkt\_2\_v1\_0 as shown in Figure 6–1.

Figure 6-1: AXI4-Stream Data Flow Control and Packetizer 2 Core in Pentek IP Catalog



## 6.1 Pentek IP Catalog (continued)

When you select the **px\_axis\_pdti2ppkt\_2\_v1\_0** core, a screen appears that shows the core's symbol and the core's parameters (see Figure 6–2). The core's symbol is the box on the left side.

Figure 6-2: AXI4-Stream Data Flow Control and Packetizer 2 Core IP Symbol



### 6.2 User Parameters

This section is not applicable to this IP core.

## 6.3 Generating Output

For more details about generating and using IP in the Vivado Design Suite, refer to the *Vivado Design Suite User Guide – Designing with IP*.

## 6.4 Constraining the Core

This section contains information about constraining the Packetizer Core in Vivado Design Suite.

### **Required Constraints**

The XDC constraints are not provided with the Packetizer Core. Clock constraints can be applied in the top–level module of the user design.

### Device, Package, and Speed Grade Selections

This IP works for the Kintex Ultrascale FPGAs.

### **Clock Frequencies**

The clock (s\_axi\_csr\_aclk) can take frequencies up to 250 MHz. The sample clock (s axis aclk) has a maximum frequency of 350 MHz.

### **Clock Management**

This section is not applicable for this IP core.

#### **Clock Placement**

This section is not applicable for this IP core.

### **Banking and Placement**

This section is not applicable for this IP core.

### **Transceiver Placement**

This section is not applicable for this IP core.

#### I/O Standard and Placement

This section is not applicable for this IP core.

## 6.5 Simulation

The Packetizer Core has a test bench which generates output waveforms using the Vivado VSim environment. The test bench is designed to run at 200 MHz AXI4–Stream clock frequency and 250 MHz CSR clock frequency.

The test bench provides control register values through a **test\_parameters.txt** file. The parameter defined in the **test\_parameters.txt** file is described in Table 6–1. The control registers within the core are written with the values from the text file and verified by reading from them.

| Table 6–1: Test Parameters File Contents and Parameter Descriptions |                                                             |            |                                                                                                                                                                                                                                                                       |  |  |  |  |
|---------------------------------------------------------------------|-------------------------------------------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Parameter                                                           | Туре                                                        | Value      | Description                                                                                                                                                                                                                                                           |  |  |  |  |
| mode_sel std_logic _vector  data_mode_sel                           |                                                             | 0x1        | Mode Select: This parameter is used to define the mode of operation of the core. It defines the source of the data acquisition gate signal generated by the core. (See Table 4-2)  0x0 = Gate mode  0x1 = Trigger mode  0x2 = Trigger Hold mode  0x3 = Timestamp mode |  |  |  |  |
|                                                                     |                                                             | 0x0        | Data Mode Select: This parameter defines the data type of the input data to the Packetizer Core.  0 = Dual Sample Real Data 1 = Packed I/Q Data                                                                                                                       |  |  |  |  |
| stay_armed                                                          | Boolean                                                     | True       | Stay Armed: When set to True, the trigger control state machine is held in the armed state.                                                                                                                                                                           |  |  |  |  |
| trigger_dly_value                                                   | trigger_dly_value std_logic _vector 0x trigger_len_value 0x |            | Trigger Delay Value: This is the delay to be introduced to the data acquisition gate signal after a trigger event has occurred.                                                                                                                                       |  |  |  |  |
| trigger_len_value                                                   |                                                             |            | Trigger Length Value: This is the length of the data acquisition gate signal generated by the gate/trigger generator module.                                                                                                                                          |  |  |  |  |
| timestamp_strt_<br>lwr_val                                          |                                                             | 0x00000100 | <b>Timestamp Start Lower DWord:</b> This is the lower dword of the start value of the timestamp in the timestamp range.                                                                                                                                               |  |  |  |  |
| timestamp_strt_<br>upr_val                                          | • — —                                                       |            | <b>Timestamp Start Upper DWord:</b> This is the upper dword of the start value of the timestamp in the timestamp range.                                                                                                                                               |  |  |  |  |
| · ·                                                                 |                                                             |            | <b>Timestamp End Lower DWord:</b> This is the lower dword of the end value of the timestamp in the timestamp range.                                                                                                                                                   |  |  |  |  |
| timestamp_end_<br>upr_val                                           |                                                             | 0x00000000 | <b>Timestamp End Upper DWord:</b> This is the upper dword of the end value of the timestamp in the timestamp range.                                                                                                                                                   |  |  |  |  |

## 6.5 Simulation (continued)

The test bench has the core operating in the Trigger mode and data mode set to Single Sample Real data. Once the trigger control state machine is armed, the input data to the core is generated using an up counter starting from 0x0000. The acquisition gate trigger length is set to 16 AXI4–Stream clock cycles and has no trigger delay. When run, the simulation produces the results shown in Figure 6–3.

Name Value 1,000 ns 2,500 ns s\_axi\_csr\_adk ↓ s\_axi\_csr\_aresetn 00 00 ■ ■ s\_axi\_csr\_awprot[2:0] ₲ s\_axi\_csr\_awvalid 0 s\_axi\_csr\_awready ШШ 🔣 💐 s\_axi\_csr\_wdata[31:0] 00000006 00000006 00000000 X 00000 (00000 X ■ ■ s\_axi\_csr\_wstrb[3:0] 0 s axi csr wvalid 111111111 s\_axi\_csr\_wready ■ s\_axi\_csr\_bresp[1:0] 111111111 s\_axi\_csr\_bvalid 🖟 s\_axi\_csr\_bready ■ ■ s\_axi\_csr\_araddr[5:0] 20 20 34 s\_axi\_csr\_arprot[2:0]

s\_axi\_csr\_arprot[2:0] 🖟 s\_axi\_csr\_arvalid ШШШ I s axi csr arready 🖪 💐 s\_axi\_csr\_rdata[31:0] 0000000a 00000000 d000000f 0000000a 🔣 😽 s\_axi\_csr\_rresp[1:0] ШШШ s axi csr rvalid s\_axi\_csr\_rready Un ira ₩ s\_axis\_adk 🍇 s\_axis\_aresetn 🛨 号 s\_axis\_pdti\_tdata[31:0] 00000000 0000000021000000... s\_axis\_pdti\_tuser[127:0]
 s\_axis\_pdti\_tuser[127:0] 🖟 s\_axis\_pdti\_tvalid Im m axis pokt tvalid m\_axis\_ppkt\_tdata[31:0] UUUUUUUU טטטטטטטט **)** 80000000 🔣 💐 m\_axis\_ppkt\_tuser[79:0] 00020000000000000000 🖪 🚟 m\_axis\_ppkt\_tkeep[1:0] U m\_axis\_ppkt\_tlast reset done init\_done

Figure 6–3: AXI4–Stream Data Flow Control and Packetizer 2 Core Test Bench Simulation

## 6.6 Synthesis and Implementation

For details about synthesis and implementation see the *Vivado Design Suite User Guide – Designing with IP*.

| Δ  | $YI_{I}$        | Stroam     | Data          | Flore | Control | land | Packet | 170r 7 | ID |
|----|-----------------|------------|---------------|-------|---------|------|--------|--------|----|
| ∕┪ | 14 <del>-</del> | . <b> </b> | 1 / 1/1 / 1/1 | FIUU  |         | unu  | PUCKPI | 1/2/   | 11 |

Page 50

This page is intentionally blank