# The Axion-CL

## **Hardware Reference Manual**

BitFlow, Inc. 400 West Cummings Park, Suite 5050 Woburn, MA 01801 USA

Tel: 781-932-2900 Fax: 781-933-9965

Email: support@bitflow.com Web: www.bitflow.com

Revision A.0

## © 2016 BitFlow, Inc. All Rights Reserved.

This document, in whole or in part, may not be copied, photocopied, reproduced, translated or reduced to any other electronic medium or machine readable form without the prior written consent of BitFlow, Inc.

BitFlow, Inc. makes no implicit warranty for the use of its products and assumes no responsibility for any errors that may appear in this document, nor does it make a commitment to update the information contained in.

BitFlow, Inc. retains the right to make changes to these specifications at any time without notice.

All trademarks are properties of their respective holders.

#### Revision History:

| Revision | Date       | Comments       |
|----------|------------|----------------|
| A.0      | 2016-04-05 | First printing |

# **Table of Contents**

#### P - Preface

Purpose AXN-P-1

Support Services AXN-P-1 Technical Support AXN-P-1

Sales Support AXN-P-1 Conventions AXN-P-2

Bitfield definitions AXN-P-3

Example Bitfield Definition AXN-P-3 Bitfield Definition Explanation. AXN-P-3

#### 1 - General Description and Architecture

The Axion-CL family AXN-1-1

Camera Link AXN-1-1

Virtual vs. Hardware AXN-1-1

The Virtual Frame Grabber (VFG) AXN-1-1

Axion Configuration Spaces AXN-1-2

General Description AXN-1-3

Video Data AXN-1-4

Camera Control AXN-1-4

Camera Link Trigger Support AXN-1-5

Axion I/O system AXN-1-5

The Timing Sequencer Signal Generator AXN-1-5

The Volume Of Interest Acquisition Engine AXN-1-5

The StreamSync System AXN-1-6

Camera Link Camera Power (PoCL) AXN-1-6

Firmware AXN-1-7

Axion Camera Configuration Files AXN-1-8

BFML Camera File Modes AXN-1-8

The Axion Models AXN-1-9

## 2 - The StreamSync Acquisition Engine

Introduction AXN-2-1

The StreamSync Acquisition Engine World AXN-2-2

Controlling the StreamSync Acquisition Engine AXN-2-2

Observing the StreamSync Acquisition Engine AXN-2-4

Synchronizing the StreamSync Acquisition Engine With the Camera AXN-2-4

Regions Of Interest (ROI) with the StreamSync Acquisition Engine. AXN-2-4

Triggering the StreamSync Acquisition Engine AXN-2-6

Comparing the StreamSync Acquisition Engine to Other BitFlow products AXN-2-7

AE CON AXN-2-8

AE STATUS AXN-2-10

AE\_STREAM\_SEL AXN-2-12

V WIN DIM AXN-2-14

Z\_WIN\_CON AXN-2-16

Z\_WIN\_DIM AXN-2-20

Y WIN CON AXN-2-22

Y\_WIN\_DIM AXN-2-26

X\_WIN\_DIM AXN-2-28

V\_ACQUIRED AXN-2-30

Z\_ACQUIRED AXN-2-32

Y\_ACQUIRED AXN-2-34

X\_ACQUIRED AXN-2-36

CON489 AXN-2-38

CON490 AXN-2-41

CON548 AXN-2-43

CON549 AXN-2-46

SF DIM AXN-2-49

SF\_CON AXN-2-51

## 3 - The StreamSync Buffer Manager

Introduction AXN-3-1

The Buffer Manager Details AXN-3-2

CON485 Register AXN-3-3

CON486 Register AXN-3-5

BUF MGR CON AXN-3-7

BUF\_MGR\_TIMEOUT AXN-3-9

BOARD\_CONFIG AXN-3-11

PACKETS\_SENT\_STATUS AXN-3-13

QUADS\_USED\_STATUS AXN-3-15

QTABS USED STATUS AXN-3-17

PKT\_STAT AXN-3-19

QUADS\_LOADED\_STATUS AXN-3-22

QTABS LOADED STATUS AXN-3-24

BUF\_MGR\_STATUS AXN-3-26

PKT\_CON AXN-3-29

#### 4 - Timing Sequencer

Introduction AXN-4-1

Description AXN-4-1

TS\_CONTROL AXN-4-3

TS\_TABLE\_CONTROL AXN-4-6

TS\_TABLE\_ENTRY AXN-4-8

## 5 - The Cyton And Axion I/O System

Introduction AXN-5-1

Concepts AXN-5-1
I/O Between Virtual Frame Grabbers AXN-5-1
Overview of the Cyton and Axion I/O System Routing AXN-5-2
Input Selection AXN-5-3
Internal Signals AXN-5-4
Output Signal Selection AXN-5-6
Output Signal Routing AXN-5-7
I/O Box Output Signal Routing AXN-5-8

### 6 - The Cyton and Axion I/O System Registers

Introduction AXN-6-1 CON60 AXN-6-2 CON61 AXN-6-4 CON62 AXN-6-6 CON63 AXN-6-10 CON64 AXN-6-15 ADDR\_TRIG\_FILTER AXN-6-21 ADDR\_ENCA\_FILTER AXN-6-23 ADDR\_ENCB\_FILTER AXN-6-25

#### 7 - Encoder Divider

Introduction AXN-7-1
Encoder Divider Details AXN-7-2
Formula AXN-7-2
Example AXN-7-2
Restrictions AXN-7-2
PLL Locking AXN-7-3
Handling Encoder Slow Down or Stopping AXN-7-3
Encoder Divider Control Registers AXN-7-4

#### 8 - Quadrature Encoder

Introduction AXN-8-1

Simple Encoder Mode AXN-8-1

Positive or Negative Only Acquisition AXN-8-1

Interval Mode AXN-8-2

Re-Acquisition Prevention AXN-8-2

Scan Step Mode AXN-8-2

Combining Modes AXN-8-2

Control Registers AXN-8-2

Observability AXN-8-3

**Electrical Connections AXN-8-3** 

Understanding Stage Movement vs. Quadrature Encoder Modes AXN-8-4

## 9 - Quadrature Encoder and Divider Registers

Introduction AXN-9-1 CON65 Register AXN-9-2 CON66 Register AXN-9-4 CON67 Register AXN-9-8 CON68 Register AXN-9-11 CON69 Register AXN-9-13

#### 10 - Axion Camera Link Registers

Introduction AXN-10-1
CL\_IOBUF\_CTL AXN-10-2
CL\_CHAN\_CONFIG AXN-10-4
ADDR\_UART\_CON\_BASE AXN-10-7
ADDR\_UART\_RDAT\_BASE AXN-10-10
ADDR\_CL\_CON\_BASE AXN-10-12
ADDR\_TAP\_CON\_BASE AXN-10-14
ADDR\_TAP\_TABLE\_ADDR\_BASE AXN-10-16
ADDR\_TAP\_TABLE\_DAT\_BASE AXN-10-18
ADDR\_FLASH\_CON\_BASE AXN-10-20
ADDR\_FLASH\_ADDR\_BASE AXN-10-23
ADDR\_FLASH\_DAT\_BASE AXN-10-25

### 11 - Axion Power and Miscellaneous Registers

Introduction AXN-11-1 CON104 AXN-11-2 CON105 AXN-11-5 CON106 AXN-11-7 CON136 AXN-11-9 CON137 AXN-11-12 CON138 AXN-11-14 CON168 AXN-11-16 CON169 AXN-11-19 CON170 AXN-11-21 CON200 AXN-11-23 CON201 AXN-11-28 CON202 AXN-11-28 CON356 AXN-11-30 CON357 AXN-11-32

## 12 - Specifications

Introduction AXN-12-1 PCI Express Compatibility AXN-12-2 Maximum Pixels Per Line AXN-12-3 Maximum Lines Per Frame AXN-12-4

#### Axion Power Requirements AXN-12-5

#### 13 - Mechanical

Introduction AXN-13-1
The Axion-CL Connectors AXN-13-4
The CL Connectors AXN-13-4
Switches AXN-13-5
Jumpers AXN-13-7
Jumper JP1 AXN-13-7
Jumper JP2 AXN-13-7
LEDs AXN-13-8
Button AXN-13-9
The Auxiliary Power Connector (P4) AXN-13-10
The I/O Box Connector (P1) AXN-13-11
I/O Connector Pinout for the Axion-CL AXN-13-12

Preface Purpose

# **Preface**

# Chapter P

## P.1 Purpose

This Hardware Reference Manual is intended for anyone using the Axion-CL frame grabber. The purpose of this manual is two-fold. First, this manual completely describes how the board works. Second, it is a reference manual describing in detail the functionality of all of the board's registers.

#### P.1.1 Support Services

BitFlow, Inc. provides both sales and technical support for the Axion family of products.

#### P.1.2 Technical Support

Our web site is www.bitflow.com.

Technical support is available at 781-932-2900 from 9:00 AM to 6:00 PM Eastern Standard Time, Monday through Friday.

For technical support by email (support@bitflow.com) or by FAX (781-933-9965), please include the following:

Product name

Camera type and mode being used

Software revision number

Computer CPU type, PCI chipset, bus speed

Operating system

Example code (if applicable)

## P.1.3 Sales Support

Contact your local BitFlow Sales Representative, Dealer, or Distributor for information about how BitFlow can help you solve your most demanding camera interfacing problems. Refer to the BitFlow, Inc. web site (www.bitflow.com) for a list of North American representatives and worldwide distributors.

Purpose The Axion-CL

## P.1.4 Conventions

Table P-1 shows the conventions that are used for numerical notation in this manual.

Table P-1 Base Abbreviations

| Base        | Designator | Example |
|-------------|------------|---------|
| Binary      | b          | 1010b   |
| Decimal     | None       | 4223    |
| Hexidecimal | h          | 12fah   |

Table P-2 shows the numerical abbreviations that are used in this manual.

Table P-2 Numeric Abbreviations

| Abbreviation | Value   | Example |   |
|--------------|---------|---------|---|
| K            | 1024    | 256K    | _ |
| М            | 1048576 | 1 M     |   |

Preface Bitfield definitions

## P.2 Bitfield definitions

## P.2.1 Example Bitfield Definition

is what each bitfield definition looks like:

**BITFIELD** R/W, CON0[7..0], Axion-CL

Bitfield discussion.

## P.2.2 Bitfield Definition Explanation.

The definitions is broken into three sections (see Table P-3).

Table P-3 Bitfield Sections.

| Section Meaning |                     | Meaning                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | Bitfield name       | This is the name of the bitfield. This name is use to program this bitfield from software or from within and camera configuration file. When programming bitfields from software using a Peek or Poke function, the bitfield is preceded with "REG_". For example the bitfield CFREQ is referred to in software as REG_CFREQ.                                                                                                                                                                                                                                                                                        |
|                 | Bitfield details    | This section describes how the bitfield is accessed. The first part describes the how the bits can be accessed. For example R/W means the register can be both read and writen. See the Table P-4 for details. The second part is the wide register that the bitfield is located in. In the example above this bitfield is in CONO. Following the wide register name is a bitfield location description, in hardware engineering format. For example, [70], means the bitfield has 8 bits, location in positions 0 to 7. Finally this section also indicates if the register is specific to only one product family. |
|                 | Bitfield discussion | This section explains the purposed of the bitfield in detail.<br>Usually meaning of every possible value of the bitfield is<br>listed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

Bitfield definitions

The Axion-CL

Table P-4 explains the abbreviations used in the bitfield definitions.

Table P-4 Abbreviations

| Access     | Meaning                                                                             |
|------------|-------------------------------------------------------------------------------------|
| R/W        | Bitfield can be read and written.                                                   |
| RO         | Bitfield can only be read. Writing to this bit has no effect.                       |
| WO         | Bitfield can only be written. Reading from this bit will return meaningless values. |
| Karbon-CL  | This bitfield is functional only the Karbon-CL.                                     |
| Karbon-CXP | This bitfield is functional only the Karbon-CXP.                                    |
| Neon       | This bitfield is functional only the Neon                                           |
| R64        | This bitfield is functional only the R64 family.                                    |
| Alta       | This bitfield is functional only the Alta family.                                   |
| Cyton-CXP  | This bitfield is functional only on the Cyton-CXP family                            |
| Axion-CL   | This bitfield is functional only on the Axion-CL family                             |

AXN-P-4 BitFlow, Inc. Version A.0

# General Description and Architecture

# Chapter 1

## 1.1 The Axion-CL family

The purpose of this chapter is to explain, at a block diagram level, how the Cyton-CXP works. Currently t is two main models in the Cytron-CXP family:

AXN-PC2-1xE, support for one Base, Medium, Full or 80-bit camera AXN-PC2-2xE, support for two Base, Medium, Full or 80-bit cameras

#### 1.1.1 Camera Link

In order to understand how the Axion-CL works, it is helpful to understand the basics of Camera Link. It is beyond the scope of this manual to describe how Camera Link works, however, more information on the Camera Link specification is available from http://www.visiononline.org/.

#### 1.1.2 Virtual vs. Hardware

It's important to understand how this manual works. Some chapters of this manual discuss the Axion-CL as a hardware platform (this chapter is a good example). While other chapters discuss the details of the virtual frame grabbers (VFG) that this hardware platform supports. The concept of the virtual frame grabber is described below, but basically the idea is that one hardware platform can support more than one device. In the case of the Axion-CL, these devices are frame grabbers.

Note that we are not using the word virtual in the sense of "a software virtualization of a hardware device", these VFGs are real hardware. The reason we using "virtual" is because the term "frame grabber" has more than one meaning. It can mean the piece of hardware that you put in your computer, or it can mean the device that the your software application is controlling and getting images from. For the purposes of this manual, "virtual frame grabber" means the device that your application is interfaces with. While this might sound complicated, the implementation is simple. You plug our Cyton-CXP frame grabber into your PC, and your application interacts with one or more VFGs available. Everything else is taken care of by the BitFlow drivers.

## 1.1.3 The Virtual Frame Grabber (VFG)

The idea behind the VFG is to separate the hardware platform (connectors, laminate, FPGAs, etc.) from the frame grabbing functionality that software applications work with. The primary reason behind this separation is that the turn around time for hard-

The Axion-CL family The Axion-CL

ware is much longer than the turn around time for modifying virtual frame grabbers. To create a brand new virtual frame grabber, or to modify an existing one, simply requires writing new firmware or updating existing firmware.

The idea of modifying a frame grabber by making changes to its firmware is not new. BitFlow has been doing this since its very first product. However, unique to BitFlow products is the fact the entire frame grabber is written in firmware. The only fixed hardware components are the interfaces to the outside world (e.g. the interface chips on the front end). Everything else that makes up the board, camera control, data buffering, DMA engine, etc. is written in firmware. This gives the platform incredible levels of flexibility and opens the door to unlimited customization.

### 1.1.4 Axion Configuration Spaces

The Axion-CL model supports up to two VFGs. Each VFG appears to operating system and your software as a separate device. Each VFG will can connect to one or more CXP links. The block diagram of one VFG version, the Axion-1xE is shown in Figure 1-1. The two VFG version, Axion-2xE, is shown in Figure 1-2.

AXN-1-2 BitFlow, Inc. Version A.0

## 1.2 General Description

The Axion-CL is a x4 PCI Express Gen 2 board. It can work in any PCI Express slot that it can fit it. Usually this means an x4, x8 or x16 slot. However, some mother boards have x1 slots with x4 connectors. The Axion-CL will work in these slots, although performance my be somewhat reduced. The Axion-CL is a Gen 2 PCIe device, but it will work in Gen 1 slots, though DMA performance will be degraded. DMA performance will be the same for both Gen 2 and Gen 3 slots.



Figure 1-1 The Axion-1xE Block Diagram

General Description The Axion-CL



Figure 1-2 The Axion-2xE Block Diagram

#### 1.2.1 Video Data

Camera Link Video data is parallel digital data. The Camera Link physical layer takes a number of parallel signals and "serializes" them on to a small number of high speed signals. One the frame grabber size, the data is "de-serialized". The video data is not sent it packets. Synchronization is achieved via individual clock and synchronization signals. Data width can be from 8 to 80 bits.

#### 1.2.2 Camera Control

Camera Link facilities camera control via a RS232 serial connection. The Camera Link cable contains a bidirectional serial link. This can be used to send and receive control data to/from the camera. The serial link is always synchronous. The camera does not send data without being requested from the host.

AXN-1-4 BitFlow, Inc. Version A.0

The Camera Link specification requires frame grabber manufactures to provide a serial communications DLL which exposes a communications API. This API is open and can be used by customers in their own software. This is installed automatically when the BitFlow SDK installer is run.

Each camera vendor has its on Camera Link control protocol. T is no standard. Most camera vendors provide a Camera Control utility which uses the frame grabber serial DLL to communicate through the frame grabber to the camera. Most camera vendors also document their protocol so end users can directly program their cameras.

## 1.2.3 Camera Link Trigger Support

Camera Link supports very low latency triggering (from the frame grabber to the camera) via four dedicated signals CC1, CC2, CC3 and CC4. These can be driven by a number of different sources on the Axion-CL.

#### 1.2.4 Axion I/O system

The Axion-CL has a sophisticated I/O system, which is extremely flexible. The system take in many inputs, routes them to a number of internal signals which can be further manipulate, then routes the results to a wide rand of outputs. The I/O system is discuss in more detail in Section 7.1.

## 1.2.5 The Timing Sequencer Signal Generator

With the introduction of the Cyton-CXP, BitFlow introduced a new signal generator, the Timing Sequencer. The Axion-CL also uses this timing generator. The Timing Sequencer (TS) is more flexible and more power than the timing generators used on early BitFlow frame grabbers. It has the ability to output multiple different size pulses, each of which can free-run or require a trigger. The TS is more accurate than the NTG and has a finer granularity. The TS can also be changed on the fly, with switch overs to the new timing exactly synchronized. See section 4.1 for more information.

## 1.2.6 The Volume Of Interest Acquisition Engine

The Cyton-CXP introduces the concept of Volume of Interest (VOI) as part of its StreamSync Acquisition Engine. This has been designed from the ground up to satisfy the needs of real world machine vision application. The VOI provide robust and flexible programming that can handle of a wide variety of pixel, line, frame and sequence acquisition commands either manually from software control, or externally via hardware triggers. T is fully support for X and Y offsets, X and Y Region of interests, sequences and sequences of sequences. See section 2.2 for more information.

General Description The Axion-CL

### 1.2.7 The StreamSync System

Starting with the Cyton-CXP, BitFlow introduced a new DMA engine, the Axion-CL has this same engine. It is designed from scratch acquisition and called the StreamSync system. The StreamSync system has been designed to optimize acquisition and DMA throughput over the PCIe bus given a wider variety of internal PC conditions. In addition, the Stream Sync system has been designed to automatically resync and recover should t every be packet lost (either on the input or the output side of the board), resulting in much more usable and fault tolerant image sequences in host memory. For more information see Section 2.1 and Section 3.1.

#### 1.2.8 Camera Link Camera Power (PoCL)

The Camera Link PoCL specification specifies that the frame grabber provide up to 4 W at 12V for powering an attached camera. The Axion-CL conforms to this specification and provides power on all of its CL connectors. This can provide up to 8 W for medium/full/80-bit Camera Link cameras. Some cameras do not require power, so the Axion-CL can optionally turn power on or off via its registers. Normally this information is part of the camera configuration file, thus files for cameras that require power are so indicated.

The Axion-CL automatically powers up all connectors that need power (i.e. correctly respond to the sense circuit). This happens as soon as the system is booted.

The Axion-CL constantly monitors the current on each CXP link, if either over current or under current conditions exist, the power will be turned off. The monitoring system is purely in hardware, so no host computer intervention is required in order to safeguard the power source.

For situation w the camera requires more power than the PCle bus can supply to the frame grabber, the P4 connector can be use. This connector can be connect to the PC's power supply and all camera power will come from this connector.

AXN-1-6 BitFlow, Inc. Version A.0

#### 1.3 Firmware

Unlike many of BitFlow's previous models of frame grabbers, the Axion family does not swap firmware on the fly (this is similar to the Cyton). The Axion is shipped with firmware that supports the latest Camera Link Specification and has been tested with all known cameras at the time of the release. However new features may be added and anomalies corrected from time to time. This updates will take the form of a new firmware file (\*.fsh). You may receive an updated firmware file as part of support issue, or a new firmware release may be part of a new SDK. In general, it is best to update the firmware on your board whenever you upgrade to a major new version of the SDK.

To update the board's firmware, type to the following command in a console window:

**FWdownload** 

follow the instruction of the download program.

Note: After the firmware download process is complete, you must power down your computer in order for the new firmware to become active.

## 1.4 Axion Camera Configuration Files

The Axion is the second member of BitFlow's Gen 2 family. These frame grabber all use an XML based camera configuration file. This differs from previous models of BitFlow's frame grabbers that have all used a binary proprietary file format (which mean they could only be edited using BitFlow's tools). The file format uses the extension "BFML" but is actually an XML file with an XML compliant schema. The schema file is installed automatically and is called "BFML.xsd".

BFML files can be edited in any text editor. User's familiar with XML will understand the format right away. Users not familiar with XML files should not have too much trouble editing the files, but the XML file format is used everyw and t are many resources available for learning the format. A dedicated XML file editor can also be used, this can sometimes simplify editing when used in association with a schema file.

The BFML file format is documented on BitFlow's website. Please see the downloads page for a link to the BFML documentation.

Note: The tools used to edit previous BitFlow camera configuration files (CamEd, CamVert) can not be used to edit BFML files. We are working on a dedicated BFML editor which should be available in a future SDK release.

#### 1.4.1 BFML Camera File Modes

Previous BitFlow camera configuration file only supported a single mode of camera operation. In order to support multiple (e.g. free-running, one-shot, triggered, encoder, etc.) modes for a given camera file, multiple files were required, one for each mode. The BFML file format can contain an unlimited number of camera modes. This makes things much simpler since only one file is needed for each model of camera. Then the different modes of operation are contained within that one BFML file.

Switching between camera modes is easy, this can be done via SysReg, w each of the camera modes are enumerated, and the user can pick which mode they want to use. The modes are also available from the API. T are function to enumerate the modes and function to switch modes on the fly.

Customer can create their own modes as they see fit. They can simple copy an existing mode and change to suite t needs. The new mode should have a new name (also the comment should be updated). Once this file is save, the mode will be available in SysReg as well as from the API.

## 1.5 The Axion Models

T are two models of the Axion-CL. Table 1-1 illustrates the capabilities of each model.

Table 1-1 The Axion Models

| Capability                                 | AXN-PC2-1xE | AXN-PC2-2xE |
|--------------------------------------------|-------------|-------------|
| Number of Base CL cameras supported        | 1           | 2           |
| Number of Medium CL cameras supported      | 1           | 2           |
| Number of Full CL cameras supported        | 1           | 2           |
| Number of 80-bit CL cameras supported      | 1           | 2           |
| Number of Virtual Frame Grabbers supported | 1           | 2           |
| Number of independent trigger inputs       | 1           | 2           |
| Number of independent encoder inputs       | 1           | 2           |
| Number of PCI configurations (devices)     | 1           | 2           |
| Maximum DMA bandwidth                      | 1.75 GB/S   | 1.75 GB/S   |

The Axion Models

The Axion-CL

# The StreamSync Acquisition Engine

# Chapter 2

#### 2.1 Introduction

The StreamSync system consists of an Acquisition Engine and a Buffer Manager. The StreamSync system was first released on the Cyton-CXP and is a departure from previous BitFlow frame grabbers. The StreamSync system is a start-from-scratch complete redesign of the acquisition and DMA parts of a frame grabber. BitFlow used it years of experience in this area to design a next generation, super efficient capture system.

From a software perspective, the StreamSync system is compatible with the previous BitFlow products. However, digging deeper, these new system have a lot more power and flexibility. These new features will be described in the following sections.

The StreamSync system has many improvements over previous systems. The main improvements are:

Efficient support for variable sized images with fast context switches between frames

Per frame control of acquisition properties (AOI specifically)

Hardware control of image sequencing

Enhanced debug capabilities

Efficient support for on-demand buffer allocation (Genicam model)

Gracefully recovery from dropped packets (either on the input side or the DMA side)

This chapter describes the StreamSync Acquisition Engine while the next chapter describes the StreamSync Buffer Manager.

## 2.2 The StreamSync Acquisition Engine World

We are used to concept that an image has an X and a Y dimension. The Acquisition Engine expands on this concept by adding two further dimension Z and V. The Z dimension controls a sequence of frames or "Volume" of frames. The V dimension controls a sequence of volumes, or "Hypervolume". Figure 2-1 illustrates these concepts.



Figure 2-1 StreamSync Acquisition Engine Dimensions

The size of the X window, i.e. the number of pixels per line, is controlled by the X\_SIZE register. The size of the Y window, i.e. number of lines per frame, is controlled by the Y\_SIZE register. The size of the Z window, i.e. number of frames per volume, is controlled by the Z\_SIZE register. Finally, the size of the V window, i.e. number of volumes to acquire, is controlled by the V\_SIZE register. Note that the size of the Y window and the Z window can be dynamically controlled by external triggers, see below for more details.

## 2.2.1 Controlling the StreamSync Acquisition Engine

Acquisition of images is controlled by the AE\_RUN\_LEVEL register. The run level controls the conditions under which the Acquisition Engine will start or stop acquiring image data. Acquisition can be idle, which means nothing will be acquired, or it can be running, which means data will be acquired when the engine is inside the V, Z,Y and X windows. T are various conditions which control whether the engine is inside or outside of these windows.

Acquisition can be aborted on any X, Y, Z, or V boundary. The choice of boundary depends on whether one wants to abort immediate, which can cause acquisition of incomplete frames, or one wants to stop at the end of the line/frame/volume, which provides a more graceful end to acquisition.

It's easiest to think of the Acquisition Engine level in terms of a state machine. When a window is "opened" the run level moves down to the next state below. When a window "closes", the run level moves to the state above. If the window at the top level closes, the run level goes to idle. Figure 2-2 illustrates this type of state machine:



Figure 2-2 Acquisition Engine Run Level

The action that causes a window to be opened or closed depends on the type of window. Some windows can be opened in more than one way. For example the Y window can be opened when a Start Of Frame (SOF) packet is sent from the camera, or it can be opened by a trigger (all SOF packets are ignored until the trigger condition is

met) or it can just be opened immediately, as soon the Acquisition Engine level is inside the X window (i.e. the stat above). Table 2-1 enumerates all of these conditions..

Table 2-1 Open Close Conditions

| Window | Open                    | Close                                 |
|--------|-------------------------|---------------------------------------|
| V      | AE run level set to Run | Abort V, V_SIZE ZWindows              |
| Z      | Trigger, Immediate      | Trigger, Abort Z, Z_SIZE Y<br>Windows |
| Υ      | Trigger, SOF, Immediate | Trigger, Abort Y, Y_SIZE X Windows    |
| Χ      | SOL, Immediate          | Abort X, X_SIZE pixels                |

#### 2.2.2 Observing the StreamSync Acquisition Engine

The state of the Acquisition Engine can be observed at any time. The register AE\_LEVEL indicates the current run level of the Acquisition Engine. In other words, this register returns the current state as shown in Figure 2-2. While this is not very useful in a free-running situation, as the value will be changing constantly, it can be very helpful debugging if the system gets stuck (e.g. waiting for a trigger).

## 2.2.3 Synchronizing the StreamSync Acquisition Engine With the Camera

Normally acquisition is synchronized with camera by special CXP header packets called Start Of Frame (SOF) and Start Of Line (SOL). The Acquisition Engine will synchronize its Y window (frame) with the SOF and X window with the SOL. This means that all packets from the camera will be dropped until the SOF is seen (causing the Acquisition Engine to open the Y window), and then packets are further dropped until SOL must be seen (opening the X window). Each line requires an SOL packet. This process keeps the Acquisition Engine synchronize to the camera even if packets are dropped. This functionality can be enable/disable by the ZSYNC and YSYNC bitfields.

## 2.2.4 Regions Of Interest (ROI) with the StreamSync Acquisition Engine.

The Acquisition Engine support capturing a subwindow or ROI of the image that the camera is putting out. The Y\_SIZE and X\_SIZE registers control how many lines and pixels are acquired per frame, regardless of the actual frames size coming out of the camera. Further t are Y\_OFFS and X\_OFFS registers which can locate the subwindow anyw inside of the camera's frame. These concepts are show in Figure 2-3.

AXN-2-4 BitFlow, Inc. Version A.0



Camera's Frame

Figure 2-3 Acquisition Engine ROI

Similarly t is a Z\_OFFS register which if non-zero can cause the board to discard a certain number of frames before starting an acquisition of a sequence. This concept is illustrated in Figure 2-4.



Figure 2-4 Z\_OFFS Illustration

## 2.3 Triggering the StreamSync Acquisition Engine

One of the areas w the power of the Acquisition Engine is really seen is with regards to triggering. T are many more ways to use triggers in the Acquisition Engine. Primarily triggers can be used to "open" a window and/or to "close" a window. For example, a trigger could be used to start the acquisition of each frame and/or end the acquisition of each frame.

Further, a trigger could be use to start the acquisition of each volume (sequence of frames) and/or end the acquisition of a volume. Further flexibility comes from the fact that the source for each event (i.e. open or close) can be different or the same. This means a frame could started with one trigger or ended with another, or the frame could start on the rising edge and end on the falling edge of the same trigger. Please refer to Figure 2-2 for more information on w a trigger can be used to change the state of the Acquisition Engine.

# 2.4 Comparing the StreamSync Acquisition Engine to Other BitFlow products

While the Acquisition Engine might seem very complex, it is actually quite simple to use, and has considerably more power than previous acquisition engines used on all previous BitFlow frame grabbers. From a software point of view, t BitFlow API hides the differences between the traditional acquisition systems and the newer Acquisition Engine. However, for users that desire more flexibility and are willing to do some lower level code, the Acquisition Engine can handle almost any acquisition scenario.

For users who were already doing some lower level programming using other BitFlow products, it's helpful to see how this new system relates to the tradition acquisition engine. Table 2-2 shows some examples of the traditional and the new system.

Table 2-2 Comparing Traditional and New Acquisition Systems

| Traditional<br>Command | X_SIZE       | Y_SIZE        | Z_SIZE | V_SIZE | AE_RUN_<br>LEVEL |  |
|------------------------|--------------|---------------|--------|--------|------------------|--|
| Snap                   | Camera Width | Camera Height | 1      | 1      | Run              |  |
| Grab                   | Camera Width | Camera Height | 1      | 0xffff | Run              |  |
| Grab N<br>frames       | Camera Width | Camera Height | Ν      | 1      | Run              |  |
| Freeze                 |              |               |        |        | Abort Z          |  |
| Abort                  |              |               |        |        | Abort X          |  |

AE\_CON The Axion-CL

## 2.5 AE\_CON

| Bit | Name         |
|-----|--------------|
| 0   | AE_RUN_LEVEL |
| 1   | AE_RUN_LEVEL |
| 2   | AE_RUN_LEVEL |
| 3   | AE_RUN_LEVEL |
| 4   | Reserved     |
| 5   | Reserved     |
| 6   | Reserved     |
| 7   | Reserved     |
| 8   | Reserved     |
| 9   | Reserved     |
| 10  | Reserved     |
| 11  | Reserved     |
| 12  | Reserved     |
| 13  | Reserved     |
| 14  | Reserved     |
| 15  | Reserved     |
| 16  | Reserved     |
| 17  | Reserved     |
| 18  | Reserved     |
| 19  | Reserved     |
| 20  | Reserved     |
| 21  | Reserved     |
| 22  | Reserved     |
| 23  | Reserved     |
| 24  | Reserved     |
| 25  | Reserved     |
| 26  | Reserved     |
| 27  | Reserved     |
| 28  | Reserved     |
| 29  | Reserved     |
| 30  | Reserved     |
| 31  | Reserved     |

AXN-2-8 BitFlow, Inc. Version A.0

### **AE\_RUN\_LEVEL** R/W, AE\_CON[3..0], , Cyton-CXP, Axion-CL, Axion-CL

This is the main control for starting/aborting acquisition. Writing this register changes the current run level. Reading this register returns the current run level command (not the current status). The abort run levels exit acquisition on a clean boundary. V exits on a volume boundary, Z on a frame boundary, Y on a line boundary, X on a 128-byte data boundary.

| AE_RUN_LEVEL | Meaning                                              |
|--------------|------------------------------------------------------|
| 0 (0000b)    | System is idle                                       |
| 1 (0001b)    | Run - start running (i.e. acquiring)                 |
| 2 (0010b)    | Abort V - stop at the end of the next volume         |
| 3 (0011b)    | Abort Z - stop at the end of the next frame          |
| 4 (0100b)    | Abort Y - stop at the end of the next line           |
| 5 (0101b)    | Abort X - stop at the end of the next 128-byte block |

AE\_STATUS The Axion-CL

# 2.6 AE\_STATUS

| Bit | Name             |
|-----|------------------|
| 0   | AE_STATE         |
| 1   | AE_STATE         |
| 2   | AE_STATE         |
| 3   | Reserved         |
| 4   | AE_FIFO_OVERFLOW |
| 5   | Reserved         |
| 6   | Reserved         |
| 7   | Reserved         |
| 8   | Reserved         |
| 9   | Reserved         |
| 10  | Reserved         |
| 11  | Reserved         |
| 12  | Reserved         |
| 13  | Reserved         |
| 14  | Reserved         |
| 15  | Reserved         |
| 16  | Reserved         |
| 17  | Reserved         |
| 18  | Reserved         |
| 19  | Reserved         |
| 20  | Reserved         |
| 21  | Reserved         |
| 22  | Reserved         |
| 23  | Reserved         |
| 24  | Reserved         |
| 25  | Reserved         |
| 26  | Reserved         |
| 27  | Reserved         |
| 28  | Reserved         |
| 29  | Reserved         |
| 30  | Reserved         |
| 31  | Reserved         |

AXN-2-10 BitFlow, Inc. Version A.0

#### **AE\_STATE**

RO, AE\_STATUS[2..0], Cyton-CXP, Axion-CL, Axion-CL

This register indicates the current run level of the acquisition engine. The following table shows the meanings of each state.

| AE_STATE | Meaning                       |
|----------|-------------------------------|
| 0 (000b) | Idle - System is idle         |
| 1 (001b) | System is inside the V window |
| 2 (010b) | System is inside the Z window |
| 3 (011b) | System is inside the Y window |
| 4 (100b) | System is inside the X window |

#### AE\_FIFO\_ OVERFLOW

RO, AE\_STATUS[4], Cyton-CXP, Axion-CL, Axion-CL

If this bit is 1, the FIFO between acquisition engine and packet generation over-flowed. The acquisition engine will abort.

AE\_STREAM\_SEL The Axion-CL

# 2.7 AE\_STREAM\_SEL

| Bit | Name                |
|-----|---------------------|
| 0   | STREAM_SEL          |
| 1   | STREAM_SEL          |
| 2   | STREAM_SEL          |
| 3   | STREAM_SEL          |
| 4   | STREAM_SEL          |
| 5   | STREAM_SEL          |
| 6   | STREAM_SEL          |
| 7   | STREAM_SEL          |
| 8   | Reserved            |
| 9   | Reserved            |
| 10  | Reserved            |
| 11  | Reserved            |
| 12  | Reserved            |
| 13  | Reserved            |
| 14  | Reserved            |
| 15  | Reserved            |
| 16  | Reserved            |
| 17  | Reserved            |
| 18  | Reserved            |
| 19  | Reserved            |
| 20  | Reserved            |
| 21  | Reserved            |
| 22  | Reserved            |
| 23  | Reserved            |
| 24  | Reserved            |
| 25  | Reserved            |
| 26  | Reserved            |
| 27  | Reserved            |
| 28  | Reserved            |
| 29  | Reserved            |
| 30  | Reserved            |
| 31  | USE_SYNTHETIC_FRAME |

AXN-2-12 BitFlow, Inc. Version A.0

### **STREAM\_SEL** R/W, AE\_STREAM\_SEL[7..0], Cyton-CXP, Axion-CL

Program this register to the stream aggregator that this acquisition engine should get its data from. Currently only value 0 to 3 are supported. Generally this register should be programmed to correspond to the VFG number that is being use to access the acquisition engine. For example, for VFG1 set this register to 1.

USE\_ SYNTHETIC\_ FRAME R/W, AE\_STREAM\_SEL[31], Cyton-CXP, Axion-CL

Use the Synthetic Frame generator instead of the camera.

V\_WIN\_DIM The Axion-CL

# 2.8 V\_WIN\_DIM

| Bit | Name     |
|-----|----------|
| 0   | V_SIZE   |
| 1   | V_SIZE   |
| 2   | V_SIZE   |
| 3   | V_SIZE   |
| 4   | V_SIZE   |
| 5   | V_SIZE   |
| 6   | V_SIZE   |
| 7   | V_SIZE   |
| 8   | V_SIZE   |
| 9   | V_SIZE   |
| 10  | V_SIZE   |
| 11  | V_SIZE   |
| 12  | V_SIZE   |
| 13  | V_SIZE   |
| 14  | V_SIZE   |
| 15  | V_SIZE   |
| 16  | Reserved |
| 17  | Reserved |
| 18  | Reserved |
| 19  | Reserved |
| 20  | Reserved |
| 21  | Reserved |
| 22  | Reserved |
| 23  | Reserved |
| 24  | Reserved |
| 25  | Reserved |
| 26  | Reserved |
| 27  | Reserved |
| 28  | Reserved |
| 29  | Reserved |
| 30  | Reserved |
| 31  | Reserved |

AXN-2-14 BitFlow, Inc. Version A.0

## **V\_SIZE** R/W, V\_WIN\_DIM[15..0], Cyton-CXP, Axion-CL

This register defines size of the V window, that is, the number of volumes to acquire. A value of 0XFFFF means infinite. When set to infinite, the acquisition engine can be stopped by writing AE\_RUN\_LEVEL.

The most common setting for this field is either 1 or 0xFFFF.

This register is writable only when AE\_STATE is 0 (idle). Writes to this field will be ignored if AE\_STATE is not 0.

Z\_WIN\_CON The Axion-CL

## 2.9 Z\_WIN\_CON

| Bit | Name              |
|-----|-------------------|
| 0   | Z_CLOSE_TRIG_FUNC |
| 1   | Z_CLOSE_TRIG_FUNC |
| 2   | Z_CLOSE_TRIG_FUNC |
| 3   | Z_CLOSE_TRIG_FUNC |
| 4   | Z_CLOSE_TRIG_SEL  |
| 5   | Z_CLOSE_TRIG_SEL  |
| 6   | Z_CLOSE_TRIG_SEL  |
| 7   | Z_CLOSE_TRIG_SEL  |
| 8   | Z_CLOSE           |
| 9   | Z_CLOSE           |
| 10  | Z_CLOSE           |
| 11  | Z_CLOSE           |
| 12  | Z_OPEN_TRIG_FUNC  |
| 13  | Z_OPEN_TRIG_FUNC  |
| 14  | Z_OPEN_TRIG_FUNC  |
| 15  | Z_OPEN_TRIG_FUNC  |
| 16  | Z_OPEN_TRIG_SEL   |
| 17  | Z_OPEN_TRIG_SEL   |
| 18  | Z_OPEN_TRIG_SEL   |
| 19  | Z_OPEN_TRIG_SEL   |
| 20  | Z_OPEN            |
| 21  | Z_OPEN            |
| 22  | Z_OPEN            |
| 23  | Z_OPEN            |
| 24  | Z_SYNC            |
| 25  | Z_SYNC            |
| 26  | Z_SYNC            |
| 27  | Z_SYNC            |
| 28  | Reserved          |
| 29  | Reserved          |
| 30  | Reserved          |
| 31  | Reserved          |

AXN-2-16 BitFlow, Inc. Version A.0

### Z\_CLOSE\_TRIG\_ FUNC

R/W, Z\_WIN\_CON[3..0], Cyton-CXP, Axion-CL

This register determines which trigger change (if any) will end the Z window.

| Z_CLOSE_TRIG_FUNC | Meaning                 |
|-------------------|-------------------------|
| 0 (0000b)         | Rising edge of trigger  |
| 1 (0001b)         | Falling edge of trigger |
| 2 (0010b)         | Trigger is high         |
| 3 (0011b)         | Trigger is low          |
| 4 (0100b)         | Either edge of trigger  |

### Z\_CLOSE\_TRIG\_ SEL

R/W, Z\_WIN\_CON[7..4], Cyton-CXP, Axion-CL

Selects which trigger will control the end the Z window.

| Z_CLOSE_TRIG_SEL | Meaning                                        |
|------------------|------------------------------------------------|
| 0 (0000b)        | The selected trigger (VFGx_TRIG_SEL)           |
| 1 (0001b)        | The selected encoder A (VFGx_ENCA_SEL)         |
| 2 (0010b)        | The selected encoder B (VFGx_ENCB_SEL)         |
| 3 (0011b)        | The selected encoder divider (VFGx_ENCDIV_SEL) |
| 4 (0100b)        | The selected encoder quad (VFGx_ENCQ_SEL)      |

### **Z\_CLOSE**

R/W, Z\_WIN\_CON[11..8], Cyton-CXP, Axion-CL

This field specifies how the Z window closes. Possible values are: 0 - size mode, 1 - trigger mode.

If size mode is specified, the acquisition engine waits for Z\_SIZE number of complete frames, it then closes the Z window and then checks to see if t are more volumes to acquire.

If trigger mode is specified, the trigger is selected by Z\_CLOSE\_TRIG\_SEL and the conditioning function is specified by Z\_CLOSE\_TRIG\_FUNC. The acquisition engine waits for the trigger condition to be satisfied, then continues acquiring to the next frame boundary, it then closes the Z window and then checks to see if t are more volumes to acquire.

Z WIN CON The Axion-CL

#### Z\_OPEN\_TRIG\_ FUNC

R/W, Z\_WIN\_CON[15..12], Cyton-CXP, Axion-CL

This register determines which trigger change (if any) will start Z window.

| Z_OPEN_TRIG_FUNC | Meaning                 |
|------------------|-------------------------|
| 0 (0000b)        | Rising edge of trigger  |
| 1 (0001b)        | Falling edge of trigger |
| 2 (0010b)        | Trigger is high         |
| 3 (0011b)        | Trigger is low          |
| 4 (0100b)        | Either edge of trigger  |

## Z\_OPEN\_TRIG\_ SEL

R/W, Z\_WIN\_CON[19..16], Cyton-CXP, Axion-CL

Selects which trigger will control the start Z window.

| Z_OPEN_TRIG_SEL | Meaning                                        |
|-----------------|------------------------------------------------|
| 0 (0000b)       | The selected trigger (VFGx_TRIG_SEL)           |
| 1 (0001b)       | The selected encoder A (VFGx_ENCA_SEL)         |
| 2 (0010b)       | The selected encoder B (VFGx_ENCB_SEL)         |
| 3 (0011b)       | The selected encoder divider (VFGx_ENCDIV_SEL) |
| 4 (0100b)       | The selected encoder quad (VFGx_ENCQ_SEL)      |

### **Z\_OPEN**

R/W, Z\_WIN\_CON[23..20], Cyton-CXP, Axion-CL

This field specifies how the Z window starts. Possible values are: 0 - immediate mode, 1 - trigger mode.

If immediate mode is specified, no trigger synchronization is required. The acquisition engine waits for any frame sync requirements, opens the Z window, then starts the setup of the Y window.

If trigger mode is specified, the trigger is selected by Z\_OPEN\_TRIG\_SEL and the conditioning function is specified by Z\_OPEN\_TRIG\_FUNC. The acquisition engine waits for the trigger condition to be satisfied, opens the Z window, then starts the setup of the Y window.

AXN-2-18 BitFlow, Inc. Version A.0

## **Z\_SYNC** R/W, Z\_WIN\_CON[27..24], Cyton-CXP, Axion-CL

This field enforces the data-synchronization of streaming video to the acquisition engine for each individual frame in the z window. The following table shows explains this field.

| Z_SYNC | Meaning                                                                                                                                                          |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | No synchronization. All streaming packets received after the Z Window are open will be acquired as part of the current frame.                                    |
| 1      | Start Of Frame (SOF) synchronization. All streaming packets received before the SOF will be ignored. This conditions is enforced for each frame in the Z window. |

Z\_WIN\_DIM The Axion-CL

## 2.10 Z\_WIN\_DIM

| Bit | Name   |
|-----|--------|
| 0   | Z_SIZE |
| 1   | Z_SIZE |
| 2   | Z_SIZE |
| 3   | Z_SIZE |
| 4   | Z_SIZE |
| 5   | Z_SIZE |
| 6   | Z_SIZE |
| 7   | Z_SIZE |
| 8   | Z_SIZE |
| 9   | Z_SIZE |
| 10  | Z_SIZE |
| 11  | Z_SIZE |
| 12  | Z_SIZE |
| 13  | Z_SIZE |
| 14  | Z_SIZE |
| 15  | Z_SIZE |
| 16  | Z_OFFS |
| 17  | Z_OFFS |
| 18  | Z_OFFS |
| 19  | Z_OFFS |
| 20  | Z_OFFS |
| 21  | Z_OFFS |
| 22  | Z_OFFS |
| 23  | Z_OFFS |
| 24  | Z_OFFS |
| 25  | Z_OFFS |
| 26  | Z_OFFS |
| 27  | Z_OFFS |
| 28  | Z_OFFS |
| 29  | Z_OFFS |
| 30  | Z_OFFS |
| 31  | Z_OFFS |

AXN-2-20 BitFlow, Inc. Version A.0

## **Z\_SIZE** R/W, Z\_WIN\_DIM[15..0], Cyton-CXP, Axion-CL

Number of frames (Y windows) to acquire per sequence (Z windows). The acquisition of frames will only start after Z\_OFFS frames have been skipped after the Z window is opened.

## **Z\_OFFS** R/W, Z\_WIN\_DIM[31..16], Cyton-CXP, Axion-CL

The number of frames (Y windows) to skip before starting acquisition after the Z window has been opened.

Y\_WIN\_CON The Axion-CL

## 2.11 Y\_WIN\_CON

| Bit | Name              |
|-----|-------------------|
| 0   | Y_CLOSE_TRIG_FUNC |
| 1   | Y_CLOSE_TRIG_FUNC |
| 2   | Y_CLOSE_TRIG_FUNC |
| 3   | Y_CLOSE_TRIG_FUNC |
| 4   | Y_CLOSE_TRIG_SEL  |
| 5   | Y_CLOSE_TRIG_SEL  |
| 6   | Y_CLOSE_TRIG_SEL  |
| 7   | Y_CLOSE_TRIG_SEL  |
| 8   | Y_CLOSE           |
| 9   | Y_CLOSE           |
| 10  | Y_CLOSE           |
| 11  | Y_CLOSE           |
| 12  | Y_OPEN_TRIG_FUNC  |
| 13  | Y_OPEN_TRIG_FUNC  |
| 14  | Y_OPEN_TRIG_FUNC  |
| 15  | Y_OPEN_TRIG_FUNC  |
| 16  | Y_OPEN_TRIG_SEL   |
| 17  | Y_OPEN_TRIG_SEL   |
| 18  | Y_OPEN_TRIG_SEL   |
| 19  | Y_OPEN_TRIG_SEL   |
| 20  | Y_OPEN            |
| 21  | Y_OPEN            |
| 22  | Y_OPEN            |
| 23  | Y_OPEN            |
| 24  | Y_SYNC            |
| 25  | Y_SYNC            |
| 26  | Y_SYNC            |
| 27  | Y_SYNC            |
| 28  | Reserved          |
| 29  | Reserved          |
| 30  | Reserved          |
| 31  | Reserved          |

AXN-2-22 BitFlow, Inc. Version A.0

### Y\_CLOSE\_TRIG\_ FUNC

R/W, Y\_WIN\_CON[3..0], Cyton-CXP, Axion-CL

This register determines which trigger change (if any) will end the Y window.

| Y_CLOSE_TRIG_FUNC | Meaning                 |
|-------------------|-------------------------|
| 0 (0000b)         | Rising edge of trigger  |
| 1 (0001b)         | Falling edge of trigger |
| 2 (0010b)         | Trigger is high         |
| 3 (0011b)         | Trigger is low          |
| 4 (0100b)         | Either edge of trigger  |

### Y\_CLOSE\_TRIG\_ SEL

R/W, Y\_WIN\_CON[7..4], Cyton-CXP, Axion-CL

Selects which trigger will control the end the Y window.

| Y_OPEN_TRIG_SEL | Meaning                                        |
|-----------------|------------------------------------------------|
| 0 (0000b)       | The selected trigger (VFGx_TRIG_SEL)           |
| 1 (0001b)       | The selected encoder A (VFGx_ENCA_SEL)         |
| 2 (0010b)       | The selected encoder B (VFGx_ENCB_SEL)         |
| 3 (0011b)       | The selected encoder divider (VFGx_ENCDIV_SEL) |
| 4 (0100b)       | The selected encoder quad (VFGx_ENCQ_SEL)      |

### **Y\_CLOSE**

R/W, Y\_WIN\_CON[11..8], Cyton-CXP, Axion-CL

This field specifies how the Y window closes. Possible values are: 0 - size mode, 1 - trigger mode.

If size mode is specified, the acquisition engine waits for Y\_SIZEZ\_SIZE number of complete lines, it then closes the Y window and then checks to see if t are more frames to acquire.

If trigger mode is specified, the trigger is selected by Y\_CLOSE\_TRIG\_SEL and the conditioning function is specified by Y\_CLOSE\_TRIG\_FUNC. The acquisition engine waits for the trigger condition to be satisfied, then continues acquiring to the next line boundary, it then closes the Y window and then checks to see if t are more frames to acquire.

Y WIN CON The Axion-CL

#### Y\_OPEN\_TRIG\_ FUNC

R/W, Y\_WIN\_CON[15..12], Cyton-CXP, Axion-CL

This register determines which trigger change (if any) will start Y window.

| Y_OPEN_TRIG_FUNC | Meaning                 |
|------------------|-------------------------|
| 0 (0000b)        | Rising edge of trigger  |
| 1 (0001b)        | Falling edge of trigger |
| 2 (0010b)        | Trigger is high         |
| 3 (0011b)        | Trigger is low          |
| 4 (0100b)        | Either edge of trigger  |
|                  |                         |

## Y\_OPEN\_TRIG\_ SEL

R/W, Y\_WIN\_CON[19..16], Cyton-CXP, Axion-CL

Selects which trigger will control the start Y window.

| Y_OPEN_TRIG_SEL | Meaning                                        |
|-----------------|------------------------------------------------|
| 0 (0000b)       | The selected trigger (VFGx_TRIG_SEL)           |
| 1 (0001b)       | The selected encoder A (VFGx_ENCA_SEL)         |
| 2 (0010b)       | The selected encoder B (VFGx_ENCB_SEL)         |
| 3 (0011b)       | The selected encoder divider (VFGx_ENCDIV_SEL) |
| 4 (0100b)       | The selected encoder quad (VFGx_ENCQ_SEL)      |

### Y\_OPEN

R/W, Y\_WIN\_CON[23..20], Cyton-CXP, Axion-CL

This field specifies how the Y window starts. Possible values are: 0 - immediate mode, 1 - trigger mode.

If immediate mode is specified, no trigger synchronization is required. The acquisition engine waits for any line sync requirements, opens the Y window, then starts the setup of the X window.

If trigger mode is specified, the trigger is selected by Y\_OPEN\_TRIG\_SEL and the conditioning function is specified by Y\_OPEN\_TRIG\_FUNC. The acquisition engine waits for the trigger condition to be satisfied, opens the Y window, then starts the setup of the X window.

AXN-2-24 BitFlow, Inc. Version A.0

## Y\_SYNC

## R/W, Y\_WIN\_CON[27..24], Cyton-CXP, Axion-CL

This field enforces the data-synchronization of streaming video to the acquisition engine for each individual line in the y window. The following table shows explains this field.

| Y_SYNC | Meaning                                                                                                                                                        |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | No synchronization. All streaming packets received after the Y Window are open will be acquired as part of the current line.                                   |
| 1      | Start Of Line (SOL) synchronization. All streaming packets received before the SOL will be ignored. This conditions is enforced for each line in the Y window. |

Y\_WIN\_DIM The Axion-CL

## 2.12 Y\_WIN\_DIM

| Bit | Name   |
|-----|--------|
| 0   | Y_SIZE |
| 1   | Y_SIZE |
| 2   | Y_SIZE |
| 3   | Y_SIZE |
| 4   | Y_SIZE |
| 5   | Y_SIZE |
| 6   | Y_SIZE |
| 7   | Y_SIZE |
| 8   | Y_SIZE |
| 9   | Y_SIZE |
| 10  | Y_SIZE |
| 11  | Y_SIZE |
| 12  | Y_SIZE |
| 13  | Y_SIZE |
| 14  | Y_SIZE |
| 15  | Y_SIZE |
| 16  | Y_OFFS |
| 17  | Y_OFFS |
| 18  | Y_OFFS |
| 19  | Y_OFFS |
| 20  | Y_OFFS |
| 21  | Y_OFFS |
| 22  | Y_OFFS |
| 23  | Y_OFFS |
| 24  | Y_OFFS |
| 25  | Y_OFFS |
| 26  | Y_OFFS |
| 27  | Y_OFFS |
| 28  | Y_OFFS |
| 29  | Y_OFFS |
| 30  | Y_OFFS |
| 31  | Y_OFFS |

AXN-2-26 BitFlow, Inc. Version A.0

**Y\_SIZE** R/W, Y\_WIN\_DIM[15..0], Cyton-CXP, Axion-CL

Number of lines per frame (Y window) to acquire. This number is only acquired after the Y window is opened and after Y\_OFFS lines have been skipped.

**Y\_OFFS** R/W, Y\_WIN\_DIM[31..16], Cyton-CXP, Axion-CL

Number of lines to skip before starting the acquisition of lines (after the Y windows is opened).

X\_WIN\_DIM The Axion-CL

## 2.13 X\_WIN\_DIM

| Bit | Name   |
|-----|--------|
| 0   | X_SIZE |
| 1   | X_SIZE |
| 2   | X_SIZE |
| 3   | X_SIZE |
| 4   | X_SIZE |
| 5   | X_SIZE |
| 6   | X_SIZE |
| 7   | X_SIZE |
| 8   | X_SIZE |
| 9   | X_SIZE |
| 10  | X_SIZE |
| 11  | X_SIZE |
| 12  | X_SIZE |
| 13  | X_SIZE |
| 14  | X_SIZE |
| 15  | X_SIZE |
| 16  | X_OFFS |
| 17  | X_OFFS |
| 18  | X_OFFS |
| 19  | X_OFFS |
| 20  | X_OFFS |
| 21  | X_OFFS |
| 22  | X_OFFS |
| 23  | X_OFFS |
| 24  | X_OFFS |
| 25  | X_OFFS |
| 26  | X_OFFS |
| 27  | X_OFFS |
| 28  | X_OFFS |
| 29  | X_OFFS |
| 30  | X_OFFS |
| 31  | X_OFFS |

AXN-2-28 BitFlow, Inc. Version A.0

**X\_SIZE** R/W, X\_WIN\_DIM[15..0], Cyton-CXP, Axion-CL

Number of 16-byte data words to acquired per line (X window). This number is only acquired after the X window is opened and after X\_OFFS words have been skipped.

**X\_OFFS** R/W, X\_WIN\_DIM[31..16], Cyton-CXP, Axion-CL

Number of 16-byte data words to skip per line (after the Z window is opened).

V\_ACQUIRED The Axion-CL

## 2.14 V\_ACQUIRED

| Bit | Name                 |
|-----|----------------------|
| 0   | V_ACQ_COUNT          |
| 1   | V_ACQ_COUNT          |
| 2   | V_ACQ_COUNT          |
| 3   | V_ACQ_COUNT          |
| 4   | V_ACQ_COUNT          |
| 5   | V_ACQ_COUNT          |
| 6   | V_ACQ_COUNT          |
| 7   | V_ACQ_COUNT          |
| 8   | V_ACQ_COUNT          |
| 9   | V_ACQ_COUNT          |
| 10  | V_ACQ_COUNT          |
| 11  | V_ACQ_COUNT          |
| 12  | V_ACQ_COUNT          |
| 13  | V_ACQ_COUNT          |
| 14  | V_ACQ_COUNT          |
| 15  | V_ACQ_COUNT          |
| 16  | Reserved             |
| 17  | Reserved             |
| 18  | Reserved             |
| 19  | Reserved             |
| 20  | Reserved             |
| 21  | Reserved             |
| 22  | Reserved             |
| 23  | Reserved             |
| 24  | Reserved             |
| 25  | Reserved             |
| 26  | Reserved             |
| 27  | Reserved             |
| 28  | V_ACQ_COUNT_CLR_MODE |
| 29  | V_ACQ_COUNT_CLR_MODE |
| 30  | V_ACQ_COUNT_CLR_MODE |
| 31  | Reserved             |

AXN-2-30 BitFlow, Inc. Version A.0

#### **V\_ACQ\_COUNT** R/W, V\_ACQUIRED[15..0], Cyton-CXP, Axion-CL

Returns the total number of volumes (frame sequence) acquired since the last reset of this register. The behavior of this register when it reaches it maximum value depends on the register V\_ACQ\_COUNT\_CLEAR\_MODE. This register can be written to 0 by software at any time.

# **CLR\_MODE**

**V\_ACQ\_COUNT\_** R/W, V\_ACQUIRED[29..28], Cyton-CXP, Axion-CL

Controls how the V\_ACQ\_COUNT register is cleared.

| V_ACQ_COUNT_CLEAR_MODE | Meaning                                 |
|------------------------|-----------------------------------------|
| 0 (00b)                | Clear count on the start of acquisition |
| 1 (01b)                | Clear count on the start of V Window    |
| 2 (10b)                | Clear count on the start of Z Window    |
| 3 (11b)                | Clear count on the start of Y Window    |

Z\_ACQUIRED The Axion-CL

## 2.15 Z\_ACQUIRED

| Bit | Name                 |
|-----|----------------------|
| 0   | Z_ACQ_COUNT          |
| 1   | Z_ACQ_COUNT          |
| 2   | Z_ACQ_COUNT          |
| 3   | Z_ACQ_COUNT          |
| 4   | Z_ACQ_COUNT          |
| 5   | Z_ACQ_COUNT          |
| 6   | Z_ACQ_COUNT          |
| 7   | Z_ACQ_COUNT          |
| 8   | Z_ACQ_COUNT          |
| 9   | Z_ACQ_COUNT          |
| 10  | Z_ACQ_COUNT          |
| 11  | Z_ACQ_COUNT          |
| 12  | Z_ACQ_COUNT          |
| 13  | Z_ACQ_COUNT          |
| 14  | Z_ACQ_COUNT          |
| 15  | Z_ACQ_COUNT          |
| 16  | Reserved             |
| 17  | Reserved             |
| 18  | Reserved             |
| 19  | Reserved             |
| 20  | Reserved             |
| 21  | Reserved             |
| 22  | Reserved             |
| 23  | Reserved             |
| 24  | Reserved             |
| 25  | Reserved             |
| 26  | Reserved             |
| 27  | Reserved             |
| 28  | Z_ACQ_COUNT_CLR_MODE |
| 29  | Z_ACQ_COUNT_CLR_MODE |
| 30  | Reserved             |
| 31  | Reserved             |

AXN-2-32 BitFlow, Inc. Version A.0

#### **Z\_ACQ\_COUNT** R/W, Z\_ACQUIRED[15..0], Cyton-CXP, Axion-CL

Returns the total number of frames acquired since the last reset of this register. he behavior of this register when it reaches it maximum value depends on the register Z\_ ACQ\_COUNT\_CLEAR\_MODE. This register can be written to 0 by software at any time.

# CLR\_MODE

**Z\_ACQ\_COUNT\_** R/W, Z\_ACQUIRED[29..28], Cyton-CXP, Axion-CL

Controls how the Z\_ACQ\_COUNT register is cleared.

| Z_ACQ_COUNT_CLEAR_MODE | Meaning                                 |
|------------------------|-----------------------------------------|
| 0 (00b)                | Clear count on the start of acquisition |
| 1 (01b)                | Clear count on the start of V Window    |
| 2 (10b)                | Clear count on the start of Z Window    |
| 3 (11b)                | Clear count on the start of Y Window    |

Y\_ACQUIRED The Axion-CL

## 2.16 Y\_ACQUIRED

| Bit | Name                 |
|-----|----------------------|
| 0   | Y_ACQ_COUNT          |
| 1   | Y_ACQ_COUNT          |
| 2   | Y_ACQ_COUNT          |
| 3   | Y_ACQ_COUNT          |
| 4   | Y_ACQ_COUNT          |
| 5   | Y_ACQ_COUNT          |
| 6   | Y_ACQ_COUNT          |
| 7   | Y_ACQ_COUNT          |
| 8   | Y_ACQ_COUNT          |
| 9   | Y_ACQ_COUNT          |
| 10  | Y_ACQ_COUNT          |
| 11  | Y_ACQ_COUNT          |
| 12  | Y_ACQ_COUNT          |
| 13  | Y_ACQ_COUNT          |
| 14  | Y_ACQ_COUNT          |
| 15  | Y_ACQ_COUNT          |
| 16  | Reserved             |
| 17  | Reserved             |
| 18  | Reserved             |
| 19  | Reserved             |
| 20  | Reserved             |
| 21  | Reserved             |
| 22  | Reserved             |
| 23  | Reserved             |
| 24  | Reserved             |
| 25  | Reserved             |
| 26  | Reserved             |
| 27  | Reserved             |
| 28  | Y_ACQ_COUNT_CLR_MODE |
| 29  | Y_ACQ_COUNT_CLR_MODE |
| 30  | Reserved             |
| 31  | Reserved             |

AXN-2-34 BitFlow, Inc. Version A.0

#### Y\_ACQ\_COUNT R/W, Y\_ACQUIRED[15..0], Cyton-CXP, Axion-CL

Returns the total number of lines acquired since the last reset of this register. he behavior of this register when it reaches it maximum value depends on the register Y\_ ACQ\_COUNT\_CLEAR\_MODE. This register can be written to 0 by software at any time.

# **CLR\_MODE**

**Y\_ACQ\_COUNT\_** R/W, Y\_ACQUIRED[29..28], Cyton-CXP, Axion-CL

Controls how the Y\_ACQ\_COUNT register is cleared.

| Y_ACQ_COUNT_CLEAR_MODE | Meaning                                 |
|------------------------|-----------------------------------------|
| 0 (00b)                | Clear count on the start of acquisition |
| 1 (01b)                | Clear count on the start of V Window    |
| 2 (10b)                | Clear count on the start of Z Window    |
| 3 (11b)                | Clear count on the start of Y Window    |

X\_ACQUIRED The Axion-CL

## 2.17 X\_ACQUIRED

| Bit | Name                 |
|-----|----------------------|
| 0   | X_ACQ_COUNT          |
| 1   | X_ACQ_COUNT          |
| 2   | X_ACQ_COUNT          |
| 3   | X_ACQ_COUNT          |
| 4   | X_ACQ_COUNT          |
| 5   | X_ACQ_COUNT          |
| 6   | X_ACQ_COUNT          |
| 7   | X_ACQ_COUNT          |
| 8   | X_ACQ_COUNT          |
| 9   | X_ACQ_COUNT          |
| 10  | X_ACQ_COUNT          |
| 11  | X_ACQ_COUNT          |
| 12  | X_ACQ_COUNT          |
| 13  | X_ACQ_COUNT          |
| 14  | X_ACQ_COUNT          |
| 15  | X_ACQ_COUNT          |
| 16  | Reserved             |
| 17  | Reserved             |
| 18  | Reserved             |
| 19  | Reserved             |
| 20  | Reserved             |
| 21  | Reserved             |
| 22  | Reserved             |
| 23  | Reserved             |
| 24  | Reserved             |
| 25  | Reserved             |
| 26  | Reserved             |
| 27  | Reserved             |
| 28  | X_ACQ_COUNT_CLR_MODE |
| 29  | X_ACQ_COUNT_CLR_MODE |
| 30  | Reserved             |
| 31  | Reserved             |
|     |                      |

AXN-2-36 BitFlow, Inc. Version A.0

#### X\_ACQ\_COUNT R/W, X\_ACQUIRED[15..0], Cyton-CXP, Axion-CL

Returns the total number of 16-bit words acquired since the last reset of this register. he behavior of this register when it reaches it maximum value depends on the register X\_ACQ\_COUNT\_CLEAR\_MODE. This register can be written to 0 by software at any time.

# **CLR\_MODE**

**X\_ACQ\_COUNT\_** R/W, X\_ACQUIRED[29..28], Cyton-CXP, Axion-CL

Controls how the X\_ACQ\_COUNT register is cleared.

| X_ACQ_COUNT_CLEAR_MODE | Meaning                                 |
|------------------------|-----------------------------------------|
| 0 (00b)                | Clear count on the start of acquisition |
| 1 (01b)                | Clear count on the start of V Window    |
| 2 (10b)                | Clear count on the start of Z Window    |
| 3 (11b)                | Clear count on the start of Y Window    |

CON489 The Axion-CL

## 2.18 CON489

| Bit | Name                  |
|-----|-----------------------|
| 0   | INT_Z_ACQUIRED        |
| 1   | INT_Y_ACQUIRED        |
| 2   | INT_V_ACQUIRED        |
| 3   | Reserved              |
| 4   | INT_ENC_B             |
| 5   | INT_ENC_A             |
| 6   | INT_TRIG              |
| 7   | INT_Z_START           |
| 8   | INT_Y_START           |
| 9   | INT_V_START           |
| 10  | Reserved              |
| 11  | Reserved              |
| 12  | Reserved              |
| 13  | Reserved              |
| 14  | Reserved              |
| 15  | Reserved              |
| 16  | Reserved              |
| 17  | Reserved              |
| 18  | Reserved              |
| 19  | Reserved              |
| 20  | Reserved              |
| 21  | Reserved              |
| 22  | Reserved              |
| 23  | Reserved              |
| 24  | Reserved              |
| 25  | Reserved              |
| 26  | INT_BM_ERROR          |
| 27  | INT_AE_LOSS_OF_SYNC   |
| 28  | INT_PCIE_PKT_DROPPED  |
| 29  | INT_Z_ACQUIRED_LEGACY |
| 30  | Reserved              |
| 31  | Reserved              |

AXN-2-38 BitFlow, Inc. Version A.0

INT\_Z\_ R/W, CON489[0], Cyton-CXP, Axion-CL ACQUIRED

Z window closed interrupt.

INT\_Y\_ R/W, CON489[1], Cyton-CXP, Axion-CL

**ACQUIRED**Y window closed interrupt.

**INT\_V\_** R/W, CON489[2], Cyton-CXP, Axion-CL

**ACQUIRED**V window closed interrupt..

**INT\_ENC\_B** R/W, CON489[4], Cyton-CXP, Axion-CL

Encoder B interrupt.

INT\_ENC\_A R/W, CON489[5], Cyton-CXP, Axion-CL

Encoder A interrupt.

INT\_TRIG R/W, CON489[6], Cyton-CXP, Axion-CL

Trigger interrupt.

INT\_Z\_START R/W, CON489[7], Cyton-CXP, Axion-CL

Start of Z Window interrupt.

INT\_Y\_START R/W, CON489[8], Cyton-CXP, Axion-CL

Start of Y Window interrupt.

INT\_V\_START R/W, CON489[9], Cyton-CXP, Axion-CL

Start of V Window interrupt.

INT\_BM\_ERROR R/W, CON489[26], Cyton-CXP, Axion-CL

Buffer manager interrupt.

CON489 The Axion-CL

INT\_AE\_LOSS\_ R/W, CON489[27], Cyton-CXP, Axion-CL

OF\_SYNC

Loss of sync in the Acquisition Engine interrupt.

INT\_PCIE\_PKT\_ R/W, CON489[28], Cyton-CXP, Axion-CL

DROPPED

PCIe packet dropped interrupt.

INT\_Z\_ R/W, CON489[29], Cyton-CXP, Axion-CL

ACQUIRED\_ LEGACY

Copy of INT\_Z\_ACQUIRED.

AXN-2-40 BitFlow, Inc. Version A.0

## 2.19 CON490

| Bit | Name      |
|-----|-----------|
| 0   | Reserved  |
| 1   | Reserved  |
| 2   | Reserved  |
| 3   | Reserved  |
| 4   | Reserved  |
| 5   | Reserved  |
| 6   | Reserved  |
| 7   | INT_ANY   |
| 8   | ENINT_ALL |
| 9   | Reserved  |
| 10  | Reserved  |
| 11  | Reserved  |
| 12  | Reserved  |
| 13  | Reserved  |
| 14  | Reserved  |
| 15  | Reserved  |
| 16  | Reserved  |
| 17  | Reserved  |
| 18  | Reserved  |
| 19  | Reserved  |
| 20  | Reserved  |
| 21  | Reserved  |
| 22  | Reserved  |
| 23  | Reserved  |
| 24  | Reserved  |
| 25  | Reserved  |
| 26  | Reserved  |
| 27  | Reserved  |
| 28  | Reserved  |
| 29  | Reserved  |
| 30  | Reserved  |
| 31  | Reserved  |

CON490 The Axion-CL

**INT\_ANY** RO, CON490[7], Cyton-CXP, Axion-CL

T is at least on active interrupt on the board.

**ENINT\_ALL** R/W, CON490[8], Cyton-CXP, Axion-CL

Set to 1 to enable board interrupts.

AXN-2-42 BitFlow, Inc. Version A.0

## 2.20 CON548

| Bit | Name                    |
|-----|-------------------------|
| 0   | INT_Z_ACQUIRED_M        |
| 1   | INT_Y_ACQUIRED_M        |
| 2   | INT_V_ACQUIRED_M        |
| 3   | Reserved                |
| 4   | INT_ENC_B_M             |
| 5   | INT_ENC_A_M             |
| 6   | INT_TRIG_M              |
| 7   | INT_Z_START_M           |
| 8   | INT_Y_START_M           |
| 9   | INT_V_START_M           |
| 10  | Reserved                |
| 11  | Reserved                |
| 12  | Reserved                |
| 13  | Reserved                |
| 14  | Reserved                |
| 15  | Reserved                |
| 16  | Reserved                |
| 17  | Reserved                |
| 18  | Reserved                |
| 19  | Reserved                |
| 20  | Reserved                |
| 21  | Reserved                |
| 22  | Reserved                |
| 23  | Reserved                |
| 24  | Reserved                |
| 25  | Reserved                |
| 26  | INT_BM_ERROR_M          |
| 27  | INT_AE_LOSS_OF_SYNC_M   |
| 28  | INT_PCIE_PKT_DROPPED_M  |
| 29  | INT_Z_ACQUIRED_LEGACY_M |
| 30  | Reserved                |
| 31  | Reserved                |

CON548 The Axion-CL

INT Z **ACQUIRED M**  R/W, CON548[0], Cyton-CXP, Axion-CL

INT\_Z\_ACQUIRED mask.

INT Y ACQUIRED\_M R/W, CON548[1], Cyton-CXP, Axion-CL

INT\_Y\_ACQUIRED mask.

INT\_V\_ ACQUIRED\_M R/W, CON548[2], Cyton-CXP, Axion-CL

INT\_V\_ACQUIRED mask.

INT\_ENC\_B\_M

R/W, CON548[4], Cyton-CXP, Axion-CL

INT\_ENC\_B mask.

INT ENC A M

R/W, CON548[5], Cyton-CXP, Axion-CL

INT\_ENC\_A mask.

INT\_TRIG\_M

R/W, CON548[6], Cyton-CXP, Axion-CL

INT\_TRIG mask.

INT\_Z\_START\_M R/W, CON548[7], Cyton-CXP, Axion-CL

INT\_Z\_START mask.

INT\_Y\_START\_M R/W, CON548[8], Cyton-CXP, Axion-CL

INT\_Y\_START mask.

INT\_V\_START\_M R/W, CON548[9], Cyton-CXP, Axion-CL

INT\_V\_START mask.

INT BM **ERROR M**  R/W, CON548[26], Cyton-CXP, Axion-CL

INT\_BM\_ERROR mask.

INT\_AE\_LOSS\_ R/W, CON548[27], Cyton-CXP, Axion-CL

OF\_SYNC\_M

INT\_AE\_LOSS\_OF\_SYNC mask.

INT\_PCIE\_PKT\_ R/W, CON548[28], Cyton-CXP, Axion-CL

DROPPED\_M

INT\_PCIE\_PKT\_DROPPED mask.

INT\_Z\_ R/W, CON548[29], Cyton-CXP, Axion-CL ACQUIRED\_

**LEGACY\_M** INT\_Z\_ACQUIRED\_LEGACY mask.

CON549 The Axion-CL

## 2.21 CON549

| Bit | Name                     |
|-----|--------------------------|
| 0   | INT_Z_ACQUIRED_WP        |
| 1   | INT_Y_ACQUIRED_WP        |
| 2   | INT_V_ACQUIRED_WP        |
| 3   | Reserved                 |
| 4   | INT_ENC_B_WP             |
| 5   | INT_ENC_A_WP             |
| 6   | INT_TRIG_WP              |
| 7   | INT_Z_START_WP           |
| 8   | INT_Y_START_WP           |
| 9   | INT_V_START_WP           |
| 10  | Reserved                 |
| 11  | Reserved                 |
| 12  | Reserved                 |
| 13  | Reserved                 |
| 14  | Reserved                 |
| 15  | Reserved                 |
| 16  | Reserved                 |
| 17  | Reserved                 |
| 18  | Reserved                 |
| 19  | Reserved                 |
| 20  | Reserved                 |
| 21  | Reserved                 |
| 22  | Reserved                 |
| 23  | Reserved                 |
| 24  | Reserved                 |
| 25  | Reserved                 |
| 26  | INT_BM_ERROR_WP          |
| 27  | INT_AE_LOSS_OF_SYNC_WP   |
| 28  | INT_PCIE_PKT_DROPPED_WP  |
| 29  | INT_Z_ACQUIRED_LEGACY_WP |
| 30  | Reserved                 |
| 31  | Reserved                 |

AXN-2-46 BitFlow, Inc. Version A.0

**INT\_Z** R/W, CON549[0], Cyton-CXP, Axion-CL **ACQUIRED WP** 

INT\_Z\_ACQUIRED write protect.

**INT\_Y\_** R/W, CON549[1], Cyton-CXP, Axion-CL **ACQUIRED\_WP** 

INT\_Y\_ACQUIRED write protect.

**INT\_V**\_ R/W, CON549[2], Cyton-CXP, Axion-CL **ACQUIRED WP** 

INT\_V\_ACQUIRED write protect.

**INT\_ENC\_B\_WP** R/W, CON549[4], Cyton-CXP, Axion-CL

INT\_ENC\_B write protect.

INT\_ENC\_A\_WP R/W, CON549[5], Cyton-CXP, Axion-CL

INT\_ENC\_A write protect.

INT\_Z\_START\_ R/W, CON548[7], Cyton-CXP, Axion-CL WP

INT\_Z\_START write protect.

INT\_Y\_START\_ R/W, CON548[8], Cyton-CXP, Axion-CL

WP

INT\_Y\_START write protect.

INT\_V\_START\_ R/W, CON548[9], Cyton-CXP, Axion-CL

WP

**ERROR WP** 

INT\_V\_START write protect.

**INT\_TRIG\_WP** R/W, CON549[6], Cyton-CXP, Axion-CL

INT\_TRIG write protect.

INT\_BM\_ R/W, CON549[26], Cyton-CXP, Axion-CL

INT\_BM\_ERROR write protect.

CON549 The Axion-CL

**INT\_AE\_LOSS\_** R/W, CON549[27], Cyton-CXP, Axion-CL

OF\_SYNC\_WP

INT\_AE\_LOSS\_OF\_SYNC write protect.

INT\_PCIE\_PKT\_ R/W, CON549[28], Cyton-CXP, Axion-CL

DROPPED\_WP

INT\_PCIE\_PKT\_DROPPED write protect.

INT\_Z\_ R/W, CON549[29], Cyton-CXP, Axion-CL ACQUIRED\_

**LEGACY\_WP** INT\_Z\_ACQUIRED\_LEGACY write protect.

## 2.22 SF\_DIM

| 0 SF_HEIGHT 1 SF_HEIGHT 2 SF_HEIGHT 3 SF_HEIGHT 4 SF HEIGHT |  |
|-------------------------------------------------------------|--|
| 2 SF_HEIGHT<br>3 SF_HEIGHT                                  |  |
| 3 SF_HEIGHT                                                 |  |
| <del>-</del>                                                |  |
| 4 SF HEIGHT                                                 |  |
|                                                             |  |
| 5 SF_HEIGHT                                                 |  |
| 6 SF_HEIGHT                                                 |  |
| 7 SF_HEIGHT                                                 |  |
| 8 SF_HEIGHT                                                 |  |
| 9 SF_HEIGHT                                                 |  |
| 10 SF_HEIGHT                                                |  |
| 11 SF_HEIGHT                                                |  |
| 12 SF_HEIGHT                                                |  |
| 13 SF_HEIGHT                                                |  |
| 14 SF_HEIGHT                                                |  |
| 15 SF_HEIGHT                                                |  |
| 16 SF_WIDTH                                                 |  |
| 17 SF_WIDTH                                                 |  |
| 18 SF_WIDTH                                                 |  |
| 19 SF_WIDTH                                                 |  |
| 20 SF_WIDTH                                                 |  |
| 21 SF_WIDTH                                                 |  |
| 22 SF_WIDTH                                                 |  |
| 23 SF_WIDTH                                                 |  |
| 24 SF_WIDTH                                                 |  |
| 25 SF_WIDTH                                                 |  |
| 26 SF_WIDTH                                                 |  |
| 27 SF_WIDTH                                                 |  |
| 28 SF_WIDTH                                                 |  |
| 29 SF_WIDTH                                                 |  |
| 30 SF_WIDTH                                                 |  |
| 31 SF_WIDTH                                                 |  |

SF\_DIM The Axion-CL

**SF\_HEIGHT** R/W, SF\_DIM[15..0], Cyton-CXP, Axion-CL

The height (in lines) of the Synthetic Frame (internally generated synthetic image).

**SF\_WIDTH** R/W, SF\_DIM[31..16], Cyton-CXP, Axion-CL

The width of the Synthetic frame. Units are 16 byte chunks.

AXN-2-50 BitFlow, Inc. Version A.0

### 2.23 SF\_CON

| Bit | Name         |
|-----|--------------|
| 0   | SF_RUN_LEVEL |
| 1   | SF_RUN_LEVEL |
| 2   | SF_STATE     |
| 3   | SF_STATE     |
| 4   | SF_MODE      |
| 5   | SF_MODE      |
| 6   | Reserved     |
| 7   | SF_LINE_SCAN |
| 8   | SF_INIT_BYTE |
| 9   | SF_INIT_BYTE |
| 10  | SF_INIT_BYTE |
| 11  | SF_INIT_BYTE |
| 12  | SF_INIT_BYTE |
| 13  | SF_INIT_BYTE |
| 14  | SF_INIT_BYTE |
| 15  | SF_INIT_BYTE |
| 16  | SF_X_GAP     |
| 17  | SF_X_GAP     |
| 18  | SF_X_GAP     |
| 19  | SF_X_GAP     |
| 20  | SF_Y_GAP     |
| 21  | SF_Y_GAP     |
| 22  | SF_Y_GAP     |
| 23  | SF_Y_GAP     |
| 24  | SF_Z_GAP     |
| 25  | SF_Z_GAP     |
| 26  | SF_Z_GAP     |
| 27  | SF_Z_GAP     |
| 28  | SF_INC_X     |
| 29  | SF_INC_Y     |
| 30  | SF_INC_Z     |
| 31  | Reserved     |

SF CON The Axion-CL

#### **SF\_RUN\_LEVEL** R/W, SF\_CON[1..0], Cyton-CXP, Axion-CL

The register controls the Synthetic Frame generator.

| SF_RUN_LEVEL | Meaning/Command |
|--------------|-----------------|
| 0            | Idle            |
| 1            | Run             |
| 2            | Abort           |
| 3            | Reserved        |

#### SF\_STATE

RO, SF\_CON[3..2], Cyton-CXP, Axion-CL

This register controls if the Synthetic Frame generator is in free-running or triggered mode.

| SF_STATE | Meaning   |
|----------|-----------|
| 0        | Free run  |
| 1        | Triggered |
| 2        | Reserved  |
| 3        | Reserved  |

#### SF\_MODE

R/W, SF\_CON[5..4], Cyton-CXP, Axion-CL

Describe SF\_MODE.

#### SF\_LINE\_SCAN

R/W, SF\_CON[7], Cyton-CXP, Axion-CL

Setting SF\_LINE\_SCAN to one will put the Synthetic Frame generator in line scan mode .

#### SF\_INIT\_BYTE

R/W, SF\_CON[15..8], Cyton-CXP, Axion-CL

The value of the first 8-bit pixel in the synthetic frame.

#### SF\_X\_GAP

R/W, SF\_CON[19..16], Cyton-CXP, Axion-CL

The number of pixels between lines. Units are 16 byte chunks.

**SF\_Y\_GAP** R/W, SF\_CON[23..20], Cyton-CXP, Axion-CL

The number of lines between frames.

**SF\_Z\_GAP** R/W, SF\_CON[27..24], Cyton-CXP, Axion-CL

The number of frames between volumes.

**SF\_INC\_X** R/W, SF\_CON[28], Cyton-CXP, Axion-CL

The amount to increment the grey scale output value every pixel.

**SF\_INC\_Y** R/W, SF\_CON[29], Cyton-CXP, Axion-CL

The amount to increment the grey scale output value every line.

**SF\_INC\_Z** R/W, SF\_CON[30], Cyton-CXP, Axion-CL

The amount to increment the grey scale output value every frame.

SF\_CON The Axion-CL

# The StreamSync Buffer Manager

## Chapter 3

#### 3.1 Introduction

The StreamSync system consists of an Acquisition Engine and a Buffer Manager. The StreamSync system was first released on the Cyton-CXP and is a departure from previous BitFlow frame grabbers. The StreamSync system is a start-from-scratch complete redesign of the acquisition and DMA parts of a frame grabber. BitFlow used it years of experience in this area to design a next generation, super efficient capture system.

From a software perspective, the StreamSync system is compatible with the previous BitFlow products. However, digging deeper, these new system have a lot more power and flexibility. These new features will be described in the following sections.

The StreamSync system has many improvements over previous systems. The main improvements are:

Efficient support for variable sized images with fast context switches between frames

Per frame control of acquisition properties (AOI specifically)

Hardware control of image sequencing

Enhanced debug capabilities

Efficient support for on-demand buffer allocation (Genicam model)

Gracefully recovery from dropped packets (either on the input side or the DMA side)

This chapter describes the StreamSync Buffer Manager while the previous chapter describes the StreamSync Acquisition Engine.

The Buffer Manager Details The Axion-CL

### 3.2 The Buffer Manager Details

The Buffer Manager interacts with a remote, software managed, set of Scatter Gather DMA lists. A single Scatter Gather DMA list is called a QTab. A QTab is made of individual DMA instructions (descriptors) called Quads. One Quad contains the information to DMA one contiguous chunk of data from the board to host memory. The Buffer Manager reads in and precaches QTabs and the associated Quads. It makes the cached Quads and QTabs available to the Acquisition Engine in queued order. The Buffer Manager works independently of the Acquisition Engine and can be throttled by software.

The Buffer Manager and Acquisition Engine are designed to work asynchronously from each other. The Buffer Manager is capable of reading in Quads from the remote QTab while the Acquisition Engine is Running/Stopping/Aborting/or Stopped. If the local Buffer Cache fills and the Acquisition Engine is not currently consuming Quads, the Buffer Manager simply waits until room becomes available and pauses loading Quads from the remote QTab. Likewise, the Acquisition Engine is capable of acquiring frames as long as it is running and has Quad available to work on. If no Quad are available it will simply wait for more to become available from the Buffer Manager. The Acquisition Engine can accept commands of Stop/Abort/Start, all while the Buffer Manager is running independently.

The starting, stopping, and restarting of the Acquisition Engine and Buffer Manager, however, does require some synchronization. The Buffer Manager pre-fetches Quad and Quads for efficiency. This built up pipeline and caching structure requires the Acquisition Engine to be in the Stopped state before the Buffer Manager can be safely flushed. Flushing of the Buffer Manager happens when the user wants to completely shut down the StreamSync Acquisition Engine or simply start acquiring to a new QTab.

AXN-3-2 BitFlow, Inc. Version A.0

### 3.3 CON485 Register

| Bit | Name              |
|-----|-------------------|
| 0   | FIRST_QUAD_PTR_LO |
| 1   | FIRST_QUAD_PTR_LO |
| 2   | FIRST_QUAD_PTR_LO |
| 3   | FIRST_QUAD_PTR_LO |
| 4   | FIRST_QUAD_PTR_LO |
| 5   | FIRST_QUAD_PTR_LO |
| 6   | FIRST_QUAD_PTR_LO |
| 7   | FIRST_QUAD_PTR_LO |
| 8   | FIRST_QUAD_PTR_LO |
| 9   | FIRST_QUAD_PTR_LO |
| 10  | FIRST_QUAD_PTR_LO |
| 11  | FIRST_QUAD_PTR_LO |
| 12  | FIRST_QUAD_PTR_LO |
| 13  | FIRST_QUAD_PTR_LO |
| 14  | FIRST_QUAD_PTR_LO |
| 15  | FIRST_QUAD_PTR_LO |
| 16  | FIRST_QUAD_PTR_LO |
| 17  | FIRST_QUAD_PTR_LO |
| 18  | FIRST_QUAD_PTR_LO |
| 19  | FIRST_QUAD_PTR_LO |
| 20  | FIRST_QUAD_PTR_LO |
| 21  | FIRST_QUAD_PTR_LO |
| 22  | FIRST_QUAD_PTR_LO |
| 23  | FIRST_QUAD_PTR_LO |
| 24  | FIRST_QUAD_PTR_LO |
| 25  | FIRST_QUAD_PTR_LO |
| 26  | FIRST_QUAD_PTR_LO |
| 27  | FIRST_QUAD_PTR_LO |
| 28  | FIRST_QUAD_PTR_LO |
| 29  | FIRST_QUAD_PTR_LO |
| 30  | FIRST_QUAD_PTR_LO |
| 31  | FIRST_QUAD_PTR_LO |

CON485 Register The Axion-CL

#### FIRST\_QUAD\_ PTR\_LO

R/W, CON28[31..0], Cyton-CXP, Axion-CL, Axion-CL

This is the low word of the 64-bit address of the first DMA scatter-gather instruction in a chain of instructions.

AXN-3-4 BitFlow, Inc. Version A.0

### 3.4 CON486 Register

| Bit | Name              |
|-----|-------------------|
| 0   | FIRST_QUAD_PTR_HI |
| 1   | FIRST_QUAD_PTR_HI |
| 2   | FIRST_QUAD_PTR_HI |
| 3   | FIRST_QUAD_PTR_HI |
| 4   | FIRST_QUAD_PTR_HI |
| 5   | FIRST_QUAD_PTR_HI |
| 6   | FIRST_QUAD_PTR_HI |
| 7   | FIRST_QUAD_PTR_HI |
| 8   | FIRST_QUAD_PTR_HI |
| 9   | FIRST_QUAD_PTR_HI |
| 10  | FIRST_QUAD_PTR_HI |
| 11  | FIRST_QUAD_PTR_HI |
| 12  | FIRST_QUAD_PTR_HI |
| 13  | FIRST_QUAD_PTR_HI |
| 14  | FIRST_QUAD_PTR_HI |
| 15  | FIRST_QUAD_PTR_HI |
| 16  | FIRST_QUAD_PTR_HI |
| 17  | FIRST_QUAD_PTR_HI |
| 18  | FIRST_QUAD_PTR_HI |
| 19  | FIRST_QUAD_PTR_HI |
| 20  | FIRST_QUAD_PTR_HI |
| 21  | FIRST_QUAD_PTR_HI |
| 22  | FIRST_QUAD_PTR_HI |
| 23  | FIRST_QUAD_PTR_HI |
| 24  | FIRST_QUAD_PTR_HI |
| 25  | FIRST_QUAD_PTR_HI |
| 26  | FIRST_QUAD_PTR_HI |
| 27  | FIRST_QUAD_PTR_HI |
| 28  | FIRST_QUAD_PTR_HI |
| 29  | FIRST_QUAD_PTR_HI |
| 30  | FIRST_QUAD_PTR_HI |
| 31  | FIRST_QUAD_PTR_HI |

CON486 Register The Axion-CL

#### FIRST\_QUAD\_ PTR\_HI

R/W, CON29[31..0], Cyton-CXP, Axion-CL, Axion-CL

This is the high word of the 64-bit address of the first DMA scatter-gather instruction in a chain of instructions.

AXN-3-6 BitFlow, Inc. Version A.0

### 3.5 BUF\_MGR\_CON

| Bit | Name            |
|-----|-----------------|
| 0   | BM_RUN_LEVEL    |
| 1   | BM_RUN_LEVEL    |
| 2   | BM_RUN_LEVEL    |
| 3   | BM_RUN_LEVEL    |
| 4   | Reserved        |
| 5   | Reserved        |
| 6   | Reserved        |
| 7   | Reserved        |
| 8   | Reserved        |
| 9   | Reserved        |
| 10  | Reserved        |
| 11  | Reserved        |
| 12  | Reserved        |
| 13  | Reserved        |
| 14  | Reserved        |
| 15  | Reserved        |
| 16  | Reserved        |
| 17  | Reserved        |
| 18  | Reserved        |
| 19  | Reserved        |
| 20  | Reserved        |
| 21  | Reserved        |
| 22  | Reserved        |
| 23  | Reserved        |
| 24  | CURR_FETCH_SIZE |
| 25  | CURR_FETCH_SIZE |
| 26  | CURR_FETCH_SIZE |
| 27  | CURR_FETCH_SIZE |
| 28  | MAX_FETCH_SIZE  |
| 29  | MAX_FETCH_SIZE  |
| 30  | MAX_FETCH_SIZE  |
| 31  | MAX_FETCH_SIZE  |

The Axion-CL BUF MGR CON

**BM\_RUN\_LEVEL** R/W, BUF\_MGR\_CON[3..0], Cyton-CXP, Axion-CL

This is the main control for starting/stopping the Buffer Manager.

| BM_RUN_LEVEL | Meaning                                         |
|--------------|-------------------------------------------------|
| 0 (0000b)    | Idle - The Buffer Manager is not moving data    |
| 1 (0001b)    | Run - The Buffer Manger will start to move data |
| 2 (0010b)    | Abort - Abort DMA and go to Idle                |
| 3 (0011b)    |                                                 |

#### CURR\_FETCH\_ SIZE

RO, BUF\_MGR\_CON[27..24], Cyton-CXP, Axion-CL

This is the number of Quads that will be fetched at a time by the Buffer Manager. A large read is issued over the PCIe bus to read all these Quads at one time.

| CURR_FETCH_SIZE | Meaning   |  |
|-----------------|-----------|--|
| 0 (0000b)       | 1 Quad    |  |
| 1 (0001b)       | 2 Quads   |  |
| 2 (0010b)       | 4 Quads   |  |
| 3 (0011b)       | 8 Quads   |  |
|                 |           |  |
| 15 (1111b)      | 32K Quads |  |

#### MAX\_FETCH\_ SIZE

RO, BUF\_MGR\_CON[31..28], Cyton-CXP, Axion-CL

This is the maximum number of Quads that can be fetched as a group by the Buffer Manager. The value in this register is derived as a function of the maximum PCIe read request size set by PCI enumeration.

AXN-3-8 BitFlow, Inc. Version A.0

### 3.6 BUF\_MGR\_TIMEOUT

| Bit | Name                  |
|-----|-----------------------|
| 0   | QUAD_COMPLETE_TIMEOUT |
| 1   | QUAD_COMPLETE_TIMEOUT |
| 2   | QUAD_COMPLETE_TIMEOUT |
| 3   | QUAD_COMPLETE_TIMEOUT |
| 4   | QUAD_COMPLETE_TIMEOUT |
| 5   | QUAD_COMPLETE_TIMEOUT |
| 6   | QUAD_COMPLETE_TIMEOUT |
| 7   | QUAD_COMPLETE_TIMEOUT |
| 8   | QUAD_COMPLETE_TIMEOUT |
| 9   | QUAD_COMPLETE_TIMEOUT |
| 10  | QUAD_COMPLETE_TIMEOUT |
| 11  | QUAD_COMPLETE_TIMEOUT |
| 12  | QUAD_COMPLETE_TIMEOUT |
| 13  | QUAD_COMPLETE_TIMEOUT |
| 14  | QUAD_COMPLETE_TIMEOUT |
| 15  | QUAD_COMPLETE_TIMEOUT |
| 16  | Reserved              |
| 17  | Reserved              |
| 18  | Reserved              |
| 19  | Reserved              |
| 20  | Reserved              |
| 21  | Reserved              |
| 22  | Reserved              |
| 23  | Reserved              |
| 24  | Reserved              |
| 25  | Reserved              |
| 26  | Reserved              |
| 27  | Reserved              |
| 28  | Reserved              |
| 29  | Reserved              |
| 30  | Reserved              |
| 31  | DISABLE_TIMEOUT       |

BUF MGR TIMEOUT The Axion-CL

QUAD\_ COMPLETE\_ TIMEOUT R/W, BUF\_MGR\_TIMEOUT[15..0], Cyton-CXP, Axion-CL

The maximum amount of time to wait for a Quad completion. Units are 4 nanoseconds. Writable only when BM\_STATE is Idle.

DISABLE\_ TIMEOUT R/W, BUF\_MGR\_TIMEOUT[31], Cyton-CXP, Axion-CL

Setting this bit to 1 will disable the Quad completion timeout mechanism. The Buffer Manager will wait an infinite amount of time for a Quad completion to return. For debug only. Writable only when BM\_STATE is Idle.

AXN-3-10 BitFlow, Inc. Version A.0

### 3.7 BOARD\_CONFIG

| Bit | Name       |
|-----|------------|
| 0   | SW         |
| 1   | SW         |
| 2   | Reserved   |
| 3   | Reserved   |
| 4   | CPLD_MODE  |
| 5   | CPLD_MODE  |
| 6   | CPLD_MODE  |
| 7   | CPLD_MODE  |
| 8   | Reserved   |
| 9   | Reserved   |
| 10  | Reserved   |
| 11  | Reserved   |
| 12  | CPLD_STRAP |
| 13  | CPLD_STRAP |
| 14  | CPLD_STRAP |
| 15  | Reserved   |
| 16  | Reserved   |
| 17  | Reserved   |
| 18  | Reserved   |
| 19  | Reserved   |
| 20  | Reserved   |
| 21  | Reserved   |
| 22  | Reserved   |
| 23  | Reserved   |
| 24  | Reserved   |
| 25  | Reserved   |
| 26  | Reserved   |
| 27  | Reserved   |
| 28  | Reserved   |
| 29  | Reserved   |
| 30  | Reserved   |
| 31  | Reserved   |

BOARD CONFIG The Axion-CL

**SW** RO, BOARD\_CONFIG[1..0], Cyton-CXP, Axion-CL

The current value of the on board switch SW1.

**CPLD\_MODE** RO, BOARD\_CONFIG[7..4], Cyton-CXP, Axion-CL

The current value of switch S3. This switch controls the firmware bank that the FPGA

boots from.

**CPLD\_STRAP** RO, BOARD\_CONFIG[14..12], Cyton-CXP, Axion-CL

The current value of the three on board straps.

AXN-3-12 BitFlow, Inc. Version A.0

### 3.8 PACKETS\_SENT\_STATUS

| Bit | Name             |
|-----|------------------|
| 0   | NUM_PACKETS_SENT |
| 1   | NUM_PACKETS_SENT |
| 2   | NUM_PACKETS_SENT |
| 3   | NUM_PACKETS_SENT |
| 4   | NUM_PACKETS_SENT |
| 5   | NUM_PACKETS_SENT |
| 6   | NUM_PACKETS_SENT |
| 7   | NUM_PACKETS_SENT |
| 8   | NUM_PACKETS_SENT |
| 9   | NUM_PACKETS_SENT |
| 10  | NUM_PACKETS_SENT |
| 11  | NUM_PACKETS_SENT |
| 12  | NUM_PACKETS_SENT |
| 13  | NUM_PACKETS_SENT |
| 14  | NUM_PACKETS_SENT |
| 15  | NUM_PACKETS_SENT |
| 16  | NUM_PACKETS_DROP |
| 17  | NUM_PACKETS_DROP |
| 18  | NUM_PACKETS_DROP |
| 19  | NUM_PACKETS_DROP |
| 20  | NUM_PACKETS_DROP |
| 21  | NUM_PACKETS_DROP |
| 22  | NUM_PACKETS_DROP |
| 23  | NUM_PACKETS_DROP |
| 24  | NUM_PACKETS_DROP |
| 25  | NUM_PACKETS_DROP |
| 26  | NUM_PACKETS_DROP |
| 27  | NUM_PACKETS_DROP |
| 28  | NUM_PACKETS_DROP |
| 29  | NUM_PACKETS_DROP |
| 30  | NUM_PACKETS_DROP |
| 31  | NUM_PACKETS_DROP |

The Axion-CL PACKETS SENT STATUS

#### NUM\_PACKETS\_ SENT

RO, PACKETS\_SENT\_STATUS[15..0], Cyton-CXP, Axion-CL

The register indicates the number of PCIe packets that the Buffer Manager has sent across the PCIe bus. This register rolls over to 0 at 0xffff.

# **DROP**

NUM\_PACKETS\_ RO, PACKETS\_SENT\_STATUS[31..16], Cyton-CXP, Axion-CL

This register indicates the number of PCIe packets that the buffer Manager was not able to send across the PCIe bus because the PCIe bus was busy. These packets are dropped, but the corresponding Quads are also "consumed". This means that the Buffer Manager still stays synchronized and any subsequent packets will be DMA to their correct locations.

AXN-3-14 BitFlow, Inc. Version A.0

### 3.9 QUADS\_USED\_STATUS

| Bit | Name           |
|-----|----------------|
| 0   | NUM_QUADS_USED |
| 1   | NUM_QUADS_USED |
| 2   | NUM_QUADS_USED |
| 3   | NUM_QUADS_USED |
| 4   | NUM_QUADS_USED |
| 5   | NUM_QUADS_USED |
| 6   | NUM_QUADS_USED |
| 7   | NUM_QUADS_USED |
| 8   | NUM_QUADS_USED |
| 9   | NUM_QUADS_USED |
| 10  | NUM_QUADS_USED |
| 11  | NUM_QUADS_USED |
| 12  | NUM_QUADS_USED |
| 13  | NUM_QUADS_USED |
| 14  | NUM_QUADS_USED |
| 15  | NUM_QUADS_USED |
| 16  | Reserved       |
| 17  | Reserved       |
| 18  | Reserved       |
| 19  | Reserved       |
| 20  | Reserved       |
| 21  | Reserved       |
| 22  | Reserved       |
| 23  | Reserved       |
| 24  | Reserved       |
| 25  | Reserved       |
| 26  | Reserved       |
| 27  | Reserved       |
| 28  | Reserved       |
| 29  | Reserved       |
| 30  | Reserved       |
| 31  | Reserved       |

QUADS\_USED\_STATUS The Axion-CL

#### NUM\_QUADS\_ USED

RO, QUADS\_USED\_STATUS[15..0], Cyton-CXP, Axion-CL

This register indicates the number of Quads that have been "consumed" by the Buffer Manager. This register rolls over to 0 at 0xffff.

AXN-3-16 BitFlow, Inc. Version A.0

### 3.10 QTABS\_USED\_STATUS

| Bit | Name           |
|-----|----------------|
| 0   | NUM_QTABS_USED |
| 1   | NUM_QTABS_USED |
| 2   | NUM_QTABS_USED |
| 3   | NUM_QTABS_USED |
| 4   | NUM_QTABS_USED |
| 5   | NUM_QTABS_USED |
| 6   | NUM_QTABS_USED |
| 7   | NUM_QTABS_USED |
| 8   | NUM_QTABS_USED |
| 9   | NUM_QTABS_USED |
| 10  | NUM_QTABS_USED |
| 11  | NUM_QTABS_USED |
| 12  | NUM_QTABS_USED |
| 13  | NUM_QTABS_USED |
| 14  | NUM_QTABS_USED |
| 15  | NUM_QTABS_USED |
| 16  | Reserved       |
| 17  | Reserved       |
| 18  | Reserved       |
| 19  | Reserved       |
| 20  | Reserved       |
| 21  | Reserved       |
| 22  | Reserved       |
| 23  | Reserved       |
| 24  | Reserved       |
| 25  | Reserved       |
| 26  | Reserved       |
| 27  | Reserved       |
| 28  | Reserved       |
| 29  | Reserved       |
| 30  | Reserved       |
| 31  | Reserved       |

QTABS\_USED\_STATUS The Axion-CL

#### NUM\_QTABS\_ USED

RO, QTABS\_USED\_STATUS[15..0], Cyton-CXP, Axion-CL

This register indicates the number of QTabs that have been "consumed" by the Buffer Manager. This register rolls over to 0 at 0xffff.

AXN-3-18 BitFlow, Inc. Version A.0

### 3.11 PKT\_STAT

| Bit | Name             |
|-----|------------------|
| 0   | PKT_STATE        |
| 1   | PKT_STATE        |
| 2   | Reserved         |
| 3   | Reserved         |
| 4   | Reserved         |
| 5   | Reserved         |
| 6   | Reserved         |
| 7   | Reserved         |
| 8   | NO_QUAD_AVAIL    |
| 9   | VIDEO_DROPPED    |
| 10  | QUAD_DROPPED     |
| 11  | Reserved         |
| 12  | NEW_FRAME_RESYNC |
| 13  | RD_ON_EMPTY      |
| 14  | WR_ON_FULL       |
| 15  | Reserved         |
| 16  | PKT_FLUSH_ENABLE |
| 17  | Reserved         |
| 18  | Reserved         |
| 19  | Reserved         |
| 20  | Reserved         |
| 21  | Reserved         |
| 22  | Reserved         |
| 23  | Reserved         |
| 24  | Reserved         |
| 25  | Reserved         |
| 26  | Reserved         |
| 27  | Reserved         |
| 28  | Reserved         |
| 29  | Reserved         |
| 30  | Reserved         |
| 31  | Reserved         |

PKT\_STAT The Axion-CL

#### **PKT\_STATE** RO, PKT\_STAT[1..0], Cyton-CXP, Axion-CL

Current state of the DMA engine.

| PKT_STATE | Meaning                                             |
|-----------|-----------------------------------------------------|
| 0 (00b)   | PKT_SYNC - Synchronizing DMA descriptors with video |
| 1 (01b)   | PKT_HDR - Generating PCIe header                    |
| 2 (10b)~  | PKT_DAT - Placing data in PCIe packet               |
| 3 (11b)   | Reserved                                            |
|           |                                                     |

#### NO\_QUAD\_ AVAIL

RO, PKT\_STAT[8], Cyton-CXP, Axion-CL

StreamSync DMA has data to transmit but no descriptor (effectively no valid place to send data). This indicates a problem with fetching descriptors.

#### VIDEO\_ DROPPED

RO, PKT\_STAT[9], Cyton-CXP, Axion-CL

Can occur during PKT\_SYNC as video from acquisition engine is dropped in order to resynchronize.

#### QUAD\_ DROPPED

RO, PKT\_STAT[10], Cyton-CXP, Axion-CL

Similar to VIDEO\_DROPPED but indicates quad was dropped during re-sync process when PKT\_STATE equals PKT\_SYNC.

#### NEW\_FRAME\_ RESYNC

RO, PKT\_STAT[12], Cyton-CXP, Axion-CL

Reserved.

#### **RD\_ON\_EMPTY**

RO, PKT\_STAT[13], Cyton-CXP, Axion-CL

FIFO underflow in PacketEngine.

#### WR\_ON\_FULL

R/W, PKT\_STAT[14], Cyton-CXP, Axion-CL

FIFO overflow in PacketEngine.

#### PKT\_FLUSH\_ ENABLE

R/W, PKT\_STAT[16], Cyton-CXP, Axion-CL

DMA tries to send as large as packets as possible for efficiency. Data is collected in a FIFO until certain size rules are met. However, sometimes no more data will be coming (end of frame). In this case, a timeout forces the PacketEngine to transmit the remaining data. PKT\_FLUSH\_ENABLE = 1 indicates that this has taken place.

QUADS\_LOADED\_STATUS The Axion-CL

### 3.12 QUADS\_LOADED\_STATUS

| Bit | Name             |
|-----|------------------|
| 0   | NUM_QUADS_LOADED |
| 1   | NUM_QUADS_LOADED |
| 2   | NUM_QUADS_LOADED |
| 3   | NUM_QUADS_LOADED |
| 4   | NUM_QUADS_LOADED |
| 5   | NUM_QUADS_LOADED |
| 6   | NUM_QUADS_LOADED |
| 7   | NUM_QUADS_LOADED |
| 8   | NUM_QUADS_LOADED |
| 9   | NUM_QUADS_LOADED |
| 10  | NUM_QUADS_LOADED |
| 11  | NUM_QUADS_LOADED |
| 12  | NUM_QUADS_LOADED |
| 13  | NUM_QUADS_LOADED |
| 14  | NUM_QUADS_LOADED |
| 15  | NUM_QUADS_LOADED |
| 16  | Reserved         |
| 17  | Reserved         |
| 18  | Reserved         |
| 19  | Reserved         |
| 20  | Reserved         |
| 21  | Reserved         |
| 22  | Reserved         |
| 23  | Reserved         |
| 24  | Reserved         |
| 25  | Reserved         |
| 26  | Reserved         |
| 27  | Reserved         |
| 28  | Reserved         |
| 29  | Reserved         |
| 30  | Reserved         |
| 31  | Reserved         |

AXN-3-22 BitFlow, Inc. Version A.0

#### NUM\_QUADS\_ LOADED

RO, QUADS\_LOADED\_STATUS[15..0], Cyton-CXP, Axion-CL

This register indicates the number of Quads that have been loaded by the Buffer Manager. This register will roll over to 0 at 0xffff.

QTABS\_LOADED\_STATUS The Axion-CL

### 3.13 QTABS\_LOADED\_STATUS

| Bit | Name             |
|-----|------------------|
| 0   | NUM_QTABS_LOADED |
| 1   | NUM_QTABS_LOADED |
| 2   | NUM_QTABS_LOADED |
| 3   | NUM_QTABS_LOADED |
| 4   | NUM_QTABS_LOADED |
| 5   | NUM_QTABS_LOADED |
| 6   | NUM_QTABS_LOADED |
| 7   | NUM_QTABS_LOADED |
| 8   | NUM_QTABS_LOADED |
| 9   | NUM_QTABS_LOADED |
| 10  | NUM_QTABS_LOADED |
| 11  | NUM_QTABS_LOADED |
| 12  | NUM_QTABS_LOADED |
| 13  | NUM_QTABS_LOADED |
| 14  | NUM_QTABS_LOADED |
| 15  | NUM_QTABS_LOADED |
| 16  | Reserved         |
| 17  | Reserved         |
| 18  | Reserved         |
| 19  | Reserved         |
| 20  | Reserved         |
| 21  | Reserved         |
| 22  | Reserved         |
| 23  | Reserved         |
| 24  | Reserved         |
| 25  | Reserved         |
| 26  | Reserved         |
| 27  | Reserved         |
| 28  | Reserved         |
| 29  | Reserved         |
| 30  | Reserved         |
| 31  | Reserved         |

AXN-3-24 BitFlow, Inc. Version A.0

#### NUM\_QTABS\_ LOADED

RO, QTABS\_LOADED\_STATUS[15..0], Cyton-CXP, Axion-CL

This register indicates the number of QTabs that have been loaded by the Buffer Manager. This register will roll over to 0 at 0xffff.

BUF\_MGR\_STATUS The Axion-CL

### 3.14 BUF\_MGR\_STATUS

| Bit | Name                  |
|-----|-----------------------|
| 0   | BM_STATE              |
| 1   | BM_STATE              |
| 2   | BM_STATE              |
| 3   | Reserved              |
| 4   | CPL_STATUS            |
| 5   | CPL_STATUS            |
| 6   | CPL_STATUS            |
| 7   | Reserved              |
| 8   | BM_QUADS_CACHED       |
| 9   | BM_QUADS_CACHED       |
| 10  | BM_QUADS_CACHED       |
| 11  | BM_QUADS_CACHED       |
| 12  | BM_QUADS_CACHED       |
| 13  | BM_QUADS_CACHED       |
| 14  | BM_QUADS_CACHED       |
| 15  | BM_QUADS_CACHED       |
| 16  | Reserved              |
| 17  | Reserved              |
| 18  | Reserved              |
| 19  | Reserved              |
| 20  | DST_ADDR_ERROR_LSB    |
| 21  | NEXT_ADDR_ERROR_LSB   |
| 22  | SIZE_ERROR_LSB        |
| 23  | SIZE_ERROR_MSB        |
| 24  | Reserved              |
| 25  | Reserved              |
| 26  | Reserved              |
| 27  | Reserved              |
| 28  | CPL_ERROR             |
| 29  | QUAD_NUM_MISMATCH     |
| 30  | QUAD_FIFO_OVERFLOW    |
| 31  | QUAD_TIMEOUT_DETECTED |

AXN-3-26 BitFlow, Inc. Version A.0

#### **BM\_STATE** RO, BUF\_MGR\_STATUS[2..0], Cyton-CXP, Axion-CL

Returns the current state of the Buffer Manager.

| Meaning                                         |
|-------------------------------------------------|
| Idle - The buffer manager is not current active |
| Active - The buffer manager is currently DMAing |
| Req64                                           |
| Req32                                           |
| Wait CPL                                        |
| Parse CPL 0                                     |
| Parse CPL 0                                     |
| Flush                                           |
|                                                 |
| JS[64], Cyton-CXP, Axion-CL                     |
| rom last received Quad.                         |
|                                                 |

#### BM\_QUADS\_ CACHED

**CPL\_STATUS** 

RO, BUF\_MGR\_STATUS[15..8], Cyton-CXP, Axion-CL

Number of QUADS currently in the cache.

#### DST\_ADDR\_ ERROR\_LSB

RO, BUF\_MGR\_STATUS[20], Cyton-CXP, Axion-CL

Quad destination address is not 16 byte aligned.

#### NEXT\_ADDR\_ ERROR\_LSB

RO, BUF\_MGR\_STATUS[21], Cyton-CXP, Axion-CL

Quad points to a next quad that is not 16-byte aligned..

#### SIZE\_ERROR\_ LSB

RO, BUF\_MGR\_STATUS[22], Cyton-CXP, Axion-CL

Quad size is not a multiple of 16 bytes..

#### SIZE\_ERROR\_ MSB

RO, BUF\_MGR\_STATUS[23], Cyton-CXP, Axion-CL

Quad size is > 4K.

BUF MGR STATUS The Axion-CL

**CPL\_ERROR** RO, BUF\_MGR\_STATUS[28], Cyton-CXP, Axion-CL

Error code received as a result of fetching a Quad. Check CPL\_STATUS.

QUAD\_NUM\_ MISMATCH RO, BUF\_MGR\_STATUS[29], Cyton-CXP, Axion-CL

Actual quad number does not match expected.

QUAD\_FIFO\_ OVERFLOW RO, BUF\_MGR\_STATUS[30], Cyton-CXP, Axion-CL

Quad cache overflowed.

QUAD\_ TIMEOUT\_ DETECTED RO, BUF\_MGR\_STATUS[31], Cyton-CXP, Axion-CL

Timeout waiting for a Quad completion. A different timeout value can be set in the

QUAD\_COMPLETE\_TIMEOUT register.

AXN-3-28 BitFlow, Inc. Version A.0

### 3.15 PKT\_CON

| Bit | Name                    |
|-----|-------------------------|
| 0   | MAX_PAYLOAD_USER        |
| 1   | MAX_PAYLOAD_USER        |
| 2   | MAX_PAYLOAD_USER        |
| 3   | MAX_PAYLOAD_USER        |
| 4   | MAX_PAYLOAD_PCIE        |
| 5   | MAX_PAYLOAD_PCIE        |
| 6   | MAX_PAYLOAD_PCIE        |
| 7   | MAX_PAYLOAD_PCIE        |
| 8   | Reserved                |
| 9   | Reserved                |
| 10  | Reserved                |
| 11  | Reserved                |
| 12  | Reserved                |
| 13  | Reserved                |
| 14  | Reserved                |
| 15  | Reserved                |
| 16  | Reserved                |
| 17  | Reserved                |
| 18  | Reserved                |
| 19  | Reserved                |
| 20  | Reserved                |
| 21  | Reserved                |
| 22  | Reserved                |
| 23  | Reserved                |
| 24  | Reserved                |
| 25  | Reserved                |
| 26  | Reserved                |
| 27  | Reserved                |
| 28  | Reserved                |
| 29  | Reserved                |
| 30  | DISABLE_PKT_FLUSH_TIMER |
| 31  | DISABLE_PKT_GEN         |

PKT CON The Axion-CL

#### MAX\_ PAYLOAD USER

RO, PKT\_CON[3..0], Cyton-CXP, Axion-CL

This is the maximum sized PCIe packet that will be generated by the Buffer Manager. Writes to this register of values higher than MAX\_PAYLOAD\_PCIE will be ignored. The coding is shown in the following table.

| MAX_PAYLOAD_USER | Meaning    |
|------------------|------------|
| 0 (0000b)        | 16 bytes   |
| 1 (0001b)        | 32 bytes   |
| 2 (0010b)        | 64 bytes   |
| 3 (0011b)        | 128 bytes  |
| 4 (0100b)        | 256 bytes  |
| 4 (0101b)        | 512 bytes  |
| 6 (0110b)        | 1024 bytes |
| 7 (0111b)        | 2048 bytes |
| 8 (1000b)        | 4096 bytes |

#### MAX\_ PAYLOAD\_PCIE

RO, PKT\_CON[7..4], Cyton-CXP, Axion-CL

This is the maximum sized PCIe write packet that can be generated by the Buffer Manager for video data. This value is set by the PCIe enumeration. The coding for this field is the same as listed under MAX\_PAYLOAD\_USER. Only values of 128 bytes to 4096 bytes are possible in PCIe, however, MAX\_PAYLOAD\_USER provides a few smaller values (16 bytes to 64 bytes) for testing purposes only. MAX\_PAYLOAD\_PCIE is status only and does not control internal logic. MAX\_PAYLOAD\_USER does control internal logic.

#### DISABLE\_PKT\_ FLUSH TIMER

R/W, PKT\_CON[30], Cyton-CXP, Axion-CL

Deactivate the timer that flushes video data to PCIe when the FIFO is inactive for an extended period.

Note: This bit is for degging purposes only.

#### DISABLE\_PKT\_ GEN

R/W, PKT\_CON[31], Cyton-CXP, Axion-CL

Disable the generation of outbound PCIe video packets. This is a final stage disable. The packet is actually generated by the logic as if it were going to be transmitted. This means that all address's and other counters increment as if the packet were generated. However it is simply dropped afterwards.

Note: This bit is for debugging purposes only.

AXN-3-30 BitFlow, Inc. Version A.0

Timing Sequencer Introduction

# **Timing Sequencer**

# Chapter 4

#### 4.1 Introduction

This section covers the Timing Sequencer (TS) which is currently only available on the Cyton-CXP. The TS is a sophisticated programmable pulse generator. The TS takes the place of the NTG on previous models of BitFlow frame grabbers.

The TS improves on the NTG in the following ways:

Driven by an "nice" clock frequency clock so that "normal" pulse sizes and periods can easily be reproduce (for example 1 micro second pulse every 10 milliseconds)

Higher accuracy signals, granularity down to 100 nanoseconds

Supports complex pulse trains of different lengths

Provides synchronize method to switch from one pulse sequence to another

Can be reprogrammed while being used (with some restrictions)

Supports triggering at arbitrary points in a pulse train

#### 4.1.1 Description

#### **TS Table**

The TS is programmed through the TS registers. The sequence of pulse that the TS will put out is programmed by building up "instructions" in the TS table. The table can hold up to 256 instructions, which can create extremely complex signals. The TS Table is programmed indirectly via address/data type registers. Once the table is programmed it can be run at any time via the TS control registers.

#### **Building Pulses**

The TS was design to support a wide range of pulse lengths. At the same time, the TS was design to be able to create pulses of very accurate duration. The solution to these two apposing problems is to build up a pulse of a desired length via multiple subpulses, each sub-pulse programmed with a different granularity. The following granularities are available:

100 seconds

100 milliseconds

100 microseconds

100 nanoseconds

Each sub pulse can have a length of 1 to 1023 units, with units are selected from the list above.

Introduction The Axion-CL

For example, let's say you want a pulse that is example 1.2345678 seconds long. This is done by programing the TS table with three sub pulse as shown below

Entry 1: 12 \* 100 milliseconds = 1.2 seconds

Entry 2: 345 \* 100 microseconds = 0.0345 seconds

Entry 3: 678 \* 100 nanoseconds = 0.0000678 seconds

When these three entries are "run", they are output one after the from the TS creating a single pulse of the desired length:

1.2 + 0.0345 + 0.0000678 = 1.2345678

As you can see, this system provides both a wide range of durations as well as very accurate durations.

Pulse can be either high or low (0 or 1). By programming both high pulses and low pulses any pulse train can be created.

#### **Chaining Pulses**

Pulses are chained together link a linked list. Each pulse entry have a "next" field which tells the system w in the table the next pulse should come from. This facility is used to build up complex sequences as well as looping sequences.

#### Triggering

Each entry in the TS table can produce one pulse. Each entry has a "condition" under which it will get executed. The conditions can be immediate, in other words, as soon as the TS gets to this entry it immediately produces the programmed pules. Or it can be programmed to wait for a trigger. Various trigger conditions are supported.

By adding this condition, the pulse train produced can be run in "one-shot" mode, w one trigger produces one pulse.

AXN-4-2 BitFlow, Inc. Version A.0

Timing Sequencer TS\_CONTROL

# 4.2 TS\_CONTROL

| Bit | Name                 |
|-----|----------------------|
| 0   | TS_RUN_LEVEL         |
| 1   | TS_RUN_LEVEL         |
| 2   | TS_RUN_LEVEL         |
| 3   | Reserved             |
| 4   | TS_CT0_DEFAULT_STATE |
| 5   | TS_CT1_DEFAULT_STATE |
| 6   | TS_CT2_DEFAULT_STATE |
| 7   | TS_CT3_DEFAULT_STATE |
| 8   | Reserved             |
| 9   | Reserved             |
| 10  | Reserved             |
| 11  | Reserved             |
| 12  | Reserved             |
| 13  | Reserved             |
| 14  | Reserved             |
| 15  | Reserved             |
| 16  | TS_IDX_JUMP          |
| 17  | TS_IDX_JUMP          |
| 18  | TS_IDX_JUMP          |
| 19  | TS_IDX_JUMP          |
| 20  | TS_IDX_JUMP          |
| 21  | TS_IDX_JUMP          |
| 22  | TS_IDX_JUMP          |
| 23  | TS_IDX_JUMP          |
| 24  | Reserved             |
| 25  | Reserved             |
| 26  | Reserved             |
| 27  | Reserved             |
| 28  | TS_TRIG_SEL          |
| 29  | TS_TRIG_SEL          |
| 30  | TS_TRIG_SEL          |
| 31  | TS_TRIG_SEL          |

TS CONTROL The Axion-CL

#### TS\_RUN\_LEVEL R/W, TS\_CONTROL[2..0], Cyton-CXP, Axion-CL, Axion-CL

These bits control the operation of the TS. These bits are used to start and stop the sequencer. They can also be used to program the table to jump to a new section. Jump are always synchronous (i.e. not immediate). Jumps will only occur from an index in the sequence that has the TS\_END\_OF\_SEQUENCE bit set.

This bit can be read at any time in order get the current status.

The following table shows the command available for this register.

| TS_RUN_LEVEL | Meaning                                                                                                                  |
|--------------|--------------------------------------------------------------------------------------------------------------------------|
| 0 (000b)     | Idle - TS is not running                                                                                                 |
| 1 (001b)     | Run - Start running immediately from index in the TS_IDX_<br>JUMP register                                               |
| 2 (010b)     | Jump - Jump to index set in the TS_IDX_JUMP register next time the current index has the TS_END_OF_SEQUENCE bit set to 1 |
| 3 (011b)     | Stop - Stop running the next time the current index has the TS_END_OF_SEQUENCE bit set to 1                              |
| 4 (100b)     | Abort - Stop running immediately                                                                                         |

#### TS\_CTO\_ DEFAULT\_STATE

R/W, TS\_CONTROL[4], Cyton-CXP, Axion-CL

This is the output state of CT0 when the TS is Idle.

# TS\_CT1\_ DEFAULT\_STATE

R/W, TS\_CONTROL[5], Cyton-CXP, Axion-CL

This is the output state of CT1 when the TS is Idle.

#### TS\_CT2\_ DEFAULT\_STATE

R/W, TS\_CONTROL[6], Cyton-CXP, Axion-CL

This is the output state of CT2 when the TS is Idle.

#### TS\_CT3\_ DEFAULT\_STATE

R/W, TS\_CONTROL[7], Cyton-CXP, Axion-CL

This is the output state of CT3 when the TS is Idle.

#### TS\_IDX\_JUMP

R/W, TS\_CONTROL[23..16], Cyton-CXP, Axion-CL

This is the entry that the table will start from when the TS\_RUN\_LEVEL register is set to Run.

AXN-4-4 BitFlow, Inc. Version A.0

Timing Sequencer TS\_CONTROL

This is the entry that the table will jump to (synchronously) the TS\_RUN\_LEVEL register is set to Jump.

### **TS\_TRIG\_SEL** R/W, TS\_CONTROL[28..31], Cyton-CXP, Axion-CL

These bits select the source of the TS trigger.

| TS_TRIG_SEL | Meaning                                              |
|-------------|------------------------------------------------------|
| 0 (000b)    | Selected trigger (VGFx_TRIG_SEL)                     |
| 1 (001b)    | Selected encoder A (VFGx_ENCA_SEL)                   |
| 2 (010b)    | Selected encoder B (VFGx_ENCB_SEL)                   |
| 3 (011b)    | Selected quad encoder output (VFGx_ENCQ_SEL)         |
| 4 (100b)    | Gated trigger (VGFx_TRIG_SEL gated by VFGx_ENCB_SEL) |
| 5 (101b)    | Selected encoder divider output (VFGx_ENCDIV_SEL)    |

TS\_TABLE\_CONTROL The Axion-CL

# 4.3 TS\_TABLE\_CONTROL

| Bit | Name          |
|-----|---------------|
| 0   | TS_IDX_ACCESS |
| 1   | TS_IDX_ACCESS |
| 2   | TS_IDX_ACCESS |
| 3   | TS_IDX_ACCESS |
| 4   | TS_IDX_ACCESS |
| 5   | TS_IDX_ACCESS |
| 6   | TS_IDX_ACCESS |
| 7   | TS_IDX_ACCESS |
| 8   | Reserved      |
| 9   | Reserved      |
| 10  | Reserved      |
| 11  | Reserved      |
| 12  | Reserved      |
| 13  | Reserved      |
| 14  | Reserved      |
| 15  | Reserved      |
| 16  | Reserved      |
| 17  | Reserved      |
| 18  | Reserved      |
| 19  | Reserved      |
| 20  | Reserved      |
| 21  | Reserved      |
| 22  | Reserved      |
| 23  | Reserved      |
| 24  | Reserved      |
| 25  | Reserved      |
| 26  | Reserved      |
| 27  | Reserved      |
| 28  | Reserved      |
| 29  | Reserved      |
| 30  | Reserved      |
| 31  | Reserved      |

AXN-4-6 BitFlow, Inc. Version A.0

Timing Sequencer TS\_TABLE\_CONTROL

# **TS\_IDX\_ACCESS** R/W, TS\_TABLE\_CONTROL[7..0], Cyton-CXP, Axion-CL

Table index to access. Address is setup . Access is done through read/write to TS\_ TABLE\_ENTRY.

Version A.0 BitFlow, Inc. AXN-4-7

TS\_TABLE\_ENTRY The Axion-CL

# 4.4 TS\_TABLE\_ENTRY

| Bit | Name               |
|-----|--------------------|
| 0   | TS_NEXT            |
| 1   | TS_NEXT            |
| 2   | TS_NEXT            |
| 3   | TS_NEXT            |
| 4   | TS_NEXT            |
| 5   | TS_NEXT            |
| 6   | TS_NEXT            |
| 7   | TS_NEXT            |
| 8   | Reserved           |
| 9   | Reserved           |
| 10  | TS_RESOLUTION      |
| 11  | TS_RESOLUTION      |
| 12  | TS_STATE_CT0       |
| 13  | TS_STATE_CT1       |
| 14  | TS_STATE_CT2       |
| 15  | TS_STATE_CT3       |
| 16  | Reserved           |
| 17  | TS_COUNT           |
| 18  | TS_COUNT           |
| 19  | TS_COUNT           |
| 20  | TS_COUNT           |
| 21  | TS_COUNT           |
| 22  | TS_COUNT           |
| 23  | TS_COUNT           |
| 24  | TS_COUNT           |
| 25  | TS_COUNT           |
| 26  | TS_COUNT           |
| 27  | TS_CONDITION       |
| 28  | TS_CONDITION       |
| 29  | TS_CONDITION       |
| 30  | TS_TERMINATE       |
| 31  | TS_END_OF_SEQUENCE |

AXN-4-8 BitFlow, Inc. Version A.0

Timing Sequencer TS\_TABLE\_ENTRY

**TS\_NEXT** R/W, TS\_TABLE\_ENTRY[7..0], Cyton-CXP, Axion-CL

Index of next pulse. Only follow if TS\_TERMINATE = 0.

**TS\_RESOLUTION** R/W, TS\_TABLE\_ENTRY[11..10], Cyton-CXP, Axion-CL

Then time units of the this pulse. The length of this pulse in the register TS\_COUNT. The following table shows the available resolutions.

| TS_RESOLUTION | Meaning          |
|---------------|------------------|
| 0 (000b)      | 100 nanoseconds  |
| 1 (001b)      | 100 microseconds |
| 2 (010b)      | 100 milliseconds |
| 3 (011b)      | 100 seconds      |

**TS\_STATE\_CTO** R/W, TS\_TABLE\_ENTRY[12], Cyton-CXP, Axion-CL

The level of the CTO signal for this pulse.

**TS\_STATE\_CT1** R/W, TS\_TABLE\_ENTRY[13], Cyton-CXP, Axion-CL

The level of the CT1 signal for this pulse.

**TS\_STATE\_CT2** R/W, TS\_TABLE\_ENTRY[14], Cyton-CXP, Axion-CL

The level of the CT2 signal for this pulse.

TS STATE CT3 R/W, TS TABLE ENTRY[15], Cyton-CXP, Axion-CL

The level of the CT3 signal for this pulse.

**TS\_COUNT** R/W, TS\_TABLE\_ENTRY[26..17], Cyton-CXP, Axion-CL

The length of this pulse. The units for the length are set in the TS\_RESOLUTION regis-

ter.

TS TABLE ENTRY The Axion-CL

#### TS\_CONDITION

R/W, TS\_TABLE\_ENTRY[29..27], Cyton-CXP, Axion-CL

This register is used to control the conditions under which this pulse will be output. The following table shows the options for this bitfield.

| TS_CONDITION | Condition when pulse is output          |
|--------------|-----------------------------------------|
| 0 (000b)     | Immediate                               |
| 1 (001b)     | Rising edge of trigger                  |
| 2 (010b)     | Falling edge of trigger                 |
| 3 (011b)     | Trigger high                            |
| 4 (100b)     | Trigger low                             |
| 5 (101b)     | Both rising and falling edge of trigger |

#### TS TERMINATE

R/W, TS\_TABLE\_ENTRY[30], Cyton-CXP, Axion-CL

When this bit is set to 0, the table will stop running after the current pulse is output. The TS\_RUN\_LEVEL bitfield will then read back idle.

When this bit is set to 1, the table will jump to the index set in the TS\_NEXT bitfield after the current pulse is finished.

#### TS\_END\_OF\_ SEQUENCE

R/W, TS\_TABLE\_ENTRY[31], Cyton-CXP, Axion-CL

If this bit is set to 1 and TS\_RUN\_LEVEL is set to Jump, the TS will jump to the index set in the TS\_INDX\_JUMP bitfield after the current pulse is output. This bit allows for synchronous switching between one section of the table and another section.

If thte TS\_RUN\_LEVEL bitfield is not set to Jump, then this bitfield will have no effect.

If this bit is set to 0, the TS will not jump from this index.

AXN-4-10 BitFlow, Inc. Version A.0

# The Cyton And Axion I/O System

# Chapter 5

#### 5.1 Introduction

The I/O system on the Cyton and Axion family of frame grabbers are based on the Karbon-CXP with some minor changes. This system provides unprecedented flexibility. The goal of this system is to handle all the I/O needs of any machine vision application connected to the real world in a wide variety of ways. The goal is flexibility and observability.

#### 5.1.1 Concepts

The basic concept is that the outside world of a machine vision system can have a wide variety of signals, possibly using different electrical standards. The Cyton and/or Axion user can choose whichever ones best suit their needs. These inputs can then be routed to a wide range of internal destinations. Also, the board can generate its own signals of use in this system.

Once the inputs sources are chosen, they are routed to one of a number of internal signals. These internal signals can then be used to control a wide variety of functions. For example, a function might be to cause the board to acquire a frame.

Finally the internal signals can be routed off the board to a wide number of destinations. These can be used to control something in the outside world. For example, a signal might be routed such that it fires a strobe light or initiates the start of exposure in a camera.

The state of all of the possible inputs can be observed by software at any time by peeking the associated RD\_XXX bit.

#### 5.1.2 I/O Between Virtual Frame Grabbers

Because BitFlow's frame grabber can acquire from more than one camera, t has always been a contention between the desire to let each camera be independent, for example, each with its own trigger, and for them to be synchronized, all cameras using one trigger. The Cyton and Axion I/O system provides for the best of both worlds by fully supporting independent and synchronized triggers using the same flexibility as each individual VFG gets.

What this means is that one of the sources, for example, the trigger for each VFG is the master VFG (i.e. VFG0). Thus whatever signal is triggering VFG0, can also trigger all the other VFGs on the board. Of course, each VFG can choose to use the master VFG's trigger, or choose amongst its own sources. Further, the triggers can be synchronized while the encoders are independent.

# 5.2 Overview of the Cyton and Axion I/O System Routing

Figure 5-1 below shows a generic version of the I/O system routing. For each internal signal (A and B in this case) a source must be chosen. Each internal signal can be used to control one or more internal circuits or can be routed straight to an output signal. For each output signal (X & Y in this case) a source must be chosen. In addition t are internal signal generators that can be chosen as a source for an internal signal or an external signal. Even the internal signal generators can be trigger by an internal signal.

Note: Figure 5-1 is a schematic version of the actual circuit, it is greatly simplified to make it easier to understand.



Figure 5-1 Conceptual I/O System Routing

AXN-5-2 BitFlow, Inc. Version A.0

### 5.3 Input Selection

Figure 5-2 illustrates the I/O System input selection circuitry. As discussed above, each internal signal has its own selector. For each internal signal t are 64 possible sources.

Note: The signals BOX\_IN\_XXX are available via an external I/O Box, which can be mounted on an external rail system. Contact BitFlow for more information on the I/O Box.

Note: Each VFG has a copy of the circuit shown in Figure 5-2. This is why the outputs do not specify the VFG number (e.g. "VFGx\_TRIG\_SEL). However, some inputs do specify the VFG number (e.g. VFG0\_TRIG\_SEL), which means this input comes explicitly from VFG0.



Figure 5-2 I/O System Input Selection

Internal Signals The Axion-CL

# 5.4 Internal Signals

T are five internal I/O signals. The "x" in the signal name refers to VFG number of the current VFG being used. In general, the "x" is always used as all VFGs are symmetrical. The one exceptions is VFG0, which can route many of its signals to other VFGs on the same physical board. For example VFG2 out use the trigger selected on VFG 0 (i.e. VFG0\_TRIG\_SEL) as its trigger source.

- VFGx\_TRIG\_SEL normally used as a frame trigger, can also be used to initiate acquisition of N frames, or can be use to control the start and end of a frame when used with a line scan camera.
- VFGx\_ENCA\_SEL Normally used as a line trigger, to initiate the capture of one line. When using a single phase encoder, this is the signal to use.
- VFGx\_ENCB\_SEL Normally used as a line trigger when using a quadrature encoder. The encoder B should be the second phase of the quadrature encoder w Encoder A is the first phase.
- VFGx\_ENCDIV\_SEL This signal is the output of the encoder divider (multiplier) circuit. This circuit can be driven by more than one source. The output signal is correlated to the input signal, but the frequency is either divided down or multiplied up.
- VFGx\_ENCQ\_SEL This signal is the output of the quadrature encoder circuit. This circuit takes to inputs, the selected encoder A and the selected encoder B. The output signal follows the rules as programmed in to the quadrature encoder circuit, see Section 8.1 for more information.

Note: The internal signals have names such as "Trigger" and "Encoder" because they are hardwired to certain internal circuits. However, if you are not using them for this functionality, they can be use for any purpose that the routing supports.

Each of the internal signals is hardwired to a number of destinations. Even though a signal might be connected to a circuit, the circuit may not be "listening" to the signal. Each circuit has its own control registers which tells it to use a given signal or not. Figure 5-3 shows all the internal circuits that each internal signal is connected to.

The Filter is used to remove unwanted noise on the incoming signal. The filter is programmable and it will "swallow" a pulse shorter than the programmed size.

AXN-5-4 BitFlow, Inc. Version A.0



Figure 5-3 Internal Signal Routing

Output Signal Selection The Axion-CL

# 5.5 Output Signal Selection

T are four dynamic output signals for each VFG, CC1 to CC4, and twelve static output signals, GPOUT0 to GPOUT11 which are only on VFG0. The dynamic signals can be driven by a variety of sources as shown in Figure 5-4. The static signals are controlled by the values in the registers with the same names, GPOUT0 to GPOUT11 on VFG0.



Figure 5-4 Output Signal Source Selection

AXN-5-6 BitFlow, Inc. Version A.0

# 5.6 Output Signal Routing

The CCx output signals are routed to the CXP link or the board's main I/O connector Figure 5-5 illustrates how they are routed.

Note: Each VFG has an instance of the circuit shown below. This means each VFG has its own CC2 CC3 and CC4 signals present on the board's main I/O connector.

Note: The signals VFGx\_CC1 to VFGx\_CC3 can be sourced from many different signals. Please see Section 5.5 for more information on selecting the source.



Figure 5-5 Output Signal Routing

I/O Box Output Signal Routing

The Axion-CL

### 5.7 I/O Box Output Signal Routing

The I/O Box has 3 banks of 12 outputs. One bank is, TTL, one bank is differential and one bank is opto-isolated. Each bank can be driven either by the 12 on board static signals (GPOUT0 to GPOUT11 on VFG0) or the 12 dynamic signals VFG0\_CC1 to VFG3\_CC3. The choice it made on the bank level, the source for each output can not be individually selected. For example, the 12 TTL outputs can be all be driven by the static signals or all by the dynamic signals, t is no facility to mix and match. The routing of the I/O Box is shown in Figure 5-6.

Note: All of the VFGx\_CCx signals can be set to a constant value via the corresponding CCx\_SEL register. This means that in addition to the 12 static outputs controlled by VFG0's GPOUT0 to GPOUT11, t can be 12 more static outputs driver from VFG0\_CC1 to VFG3\_CC3.

Note: The I/O Box is externally rail mounted box which can take a wide variaty of inputs and outputs. It is connected to the Cyton/Axion though a small cable. Contact BitFlow for more information on the I/O Box.



Figure 5-6 I/O Box Output Signal Routing

AXN-5-8 BitFlow, Inc. Version A.0

# The Cyton and Axion I/O System Registers

# Chapter 6

#### 6.1 Introduction

The registers documented in this section are used to control the I/O system on the Cyton-CXP and the Axion-CL

CON60 The Axion-CL

## 6.2 CON60

| Bit | Name          |
|-----|---------------|
| 0   | RD_BOX_IN_TTL |
| 1   | RD_BOX_IN_TTL |
| 2   | RD_BOX_IN_TTL |
| 3   | RD_BOX_IN_TTL |
| 4   | RD_BOX_IN_TTL |
| 5   | RD_BOX_IN_TTL |
| 6   | RD_BOX_IN_TTL |
| 7   | RD_BOX_IN_TTL |
| 8   | RD_BOX_IN_TTL |
| 9   | RD_BOX_IN_TTL |
| 10  | RD_BOX_IN_TTL |
| 11  | RD_BOX_IN_TTL |
| 12  | RD_BOX_IN_DIF |
| 13  | RD_BOX_IN_DIF |
| 14  | RD_BOX_IN_DIF |
| 15  | RD_BOX_IN_DIF |
| 16  | RD_BOX_IN_DIF |
| 17  | RD_BOX_IN_DIF |
| 18  | RD_BOX_IN_DIF |
| 19  | RD_BOX_IN_DIF |
| 20  | RD_BOX_IN_DIF |
| 21  | RD_BOX_IN_DIF |
| 22  | RD_BOX_IN_DIF |
| 23  | RD_BOX_IN_DIF |
| 24  | ENINT_CXP     |
| 25  | INT_CXP       |
| 26  | Reserved      |
| 27  | Reserved      |
| 28  | Reserved      |
| 29  | SW_TRIG       |
| 30  | SW_ENCA       |
| 31  | SW_ENCB       |

AXN-6-2 BitFlow, Inc. Version A.0

RD\_BOX\_IN\_TTL RO, CON60[11..0], Cyton-CXP, Axion-CL

These bits reflect the real-time state of the 12 TTL inputs on the IO Box.

**RD BOX IN DIF** RO, CON60[23..12], Cyton-CXP, Axion-CL

These bits reflect the real-time state of the 12 differential inputs on the IO Box.

**ENINT\_CXP** R/W, CON60[24], Cyton-CXP, Axion-CL

This bit enables interrupts from the CXP subsystem.

INT\_CXP RO, CON60[25], Cyton-CXP, Axion-CL

> This bit indicates the existence of an interrupt from the CXP subsystem. The individual interrupt must be cleared in the CXP subsystem in order for this bit to reset.

SW\_TRIG R/W, CON60[29], Cyton-CXP, Axion-CL

Writing the bit to 1 causes the internal trigger signal to be asserted. Writing it to a 0

will de-assert the internal trigger signal.

**SW\_ENCA** R/W, CON60[30], Cyton-CXP, Axion-CL

Writing the bit to 1 causes the internal encoder A signal to be asserted. Writing it to a

0 will de-assert the internal encoder A signal.

**SW ENCB** R/W, CON60[31], Cyton-CXP, Axion-CL

Writing the bit to 1 causes the internal encoder B signal to be asserted. Writing it to a

0 will de-assert the internal encoder B signal.

CON61 The Axion-CL

## 6.3 CON61

| Bit | Name            |
|-----|-----------------|
| 0   | RD_BOX_IN_OPTO  |
| 1   | RD_BOX_IN_OPTO  |
| 2   | RD_BOX_IN_OPTO  |
| 3   | RD_BOX_IN_OPTO  |
| 4   | RD_BOX_IN_OPTO  |
| 5   | RD_BOX_IN_OPTO  |
| 6   | RD_BOX_IN_OPTO  |
| 7   | RD_BOX_IN_OPTO  |
| 8   | RD_BOX_IN_OPTO  |
| 9   | RD_BOX_IN_OPTO  |
| 10  | RD_BOX_IN_OPTO  |
| 11  | RD_BOX_IN_OPTO  |
| 12  | Reserved        |
| 13  | Reserved        |
| 14  | Reserved        |
| 15  | Reserved        |
| 16  | Reserved        |
| 17  | Reserved        |
| 18  | Reserved        |
| 19  | Reserved        |
| 20  | Reserved        |
| 21  | Reserved        |
| 22  | Reserved        |
| 23  | RD_CXP_TRIG_OUT |
| 24  | RD_CXP_OUT_IN   |
| 25  | RD_CXP_OUT_IN   |
| 26  | RD_CXP_OUT_IN   |
| 27  | RD_CXP_OUT_IN   |
| 28  | RD_CXP_OUT_IN   |
| 29  | RD_CXP_OUT_IN   |
| 30  | RD_CXP_OUT_IN   |
| 31  | RD_CXP_OUT_IN   |

AXN-6-4 BitFlow, Inc. Version A.0

RD\_BOX\_IN\_ OPTO RO, CON61[11..0], Cyton-CXP, Axion-CL

These bits reflect the real-time state of the 12 Opto-Isolated inputs on the IO Box.

RD\_CXP\_TRIG\_ OUT RO, CON61[23], Cyton-CXP, Axion-CL

This bit reflects the real-time state of the CXP trigger signal going to the camera.

RD\_CXP\_IO\_ OUT RO, CON61[31..24], Cyton-CXP, Axion-CL

These bits reflects the real-time state of board's 8 CXP general purpose output signals going to the camera.

CON62 The Axion-CL

# 6.4 CON62

| Bit | Name             |
|-----|------------------|
| 0   | RD_TRIG_TTL      |
| 1   | RD_TRIG_DIF      |
| 2   | RD_TRIG_VFG0     |
| 3   | RD_SCAN_STEP     |
| 4   | RD_SW_TRIG       |
| 5   | RD_ENCA_TTL      |
| 6   | RD_ENCA_DIF      |
| 7   | RD_ENCA_VFG0     |
| 8   | RD_ENCA_SW       |
| 9   | RD_ENCB_TTL      |
| 10  | RD_ENCB_DIF      |
| 11  | RD_ENCB_VFG0     |
| 12  | RD_ENCB_SW       |
| 13  | RD_BUTTON        |
| 14  | Reserved         |
| 15  | Reserved         |
| 16  | RD_CXP_IO_IN     |
| 17  | RD_CXP_IO_IN     |
| 18  | RD_CXP_IO_IN     |
| 19  | RD_CXP_IO_IN     |
| 20  | RD_CXP_IO_IN     |
| 21  | RD_CXP_IO_IN     |
| 22  | RD_CXP_IO_IN     |
| 23  | RD_CXP_IO_IN     |
| 24  | RD_CXP_TRIG_IN   |
| 25  | EN_TRIG          |
| 26  | EN_ENCA          |
| 27  | EN_ENCB          |
| 28  | Reserved         |
| 29  | RD_ENCB_SELECTED |
| 30  | RD_ENCA_SELECTED |
| 31  | RD_TRIG_SELECTED |

AXN-6-6 BitFlow, Inc. Version A.0

**RD\_TRIG\_TTL** RO, CON62[0], Cyton-CXP, Axion-CL

This bit reflects the real-time state of the board's TTL trigger input.

**RD\_TRIG\_DIF** RO, CON62[1], Cyton-CXP, Axion-CL

This bit reflects the real-time state of the board's differential trigger input.

RD\_TRIG\_VFG0 RO, CON62[2], Cyton-CXP, Axion-CL

This bit reflects the real-time state of VFG0's selected trigger signal.

RD\_SCAN\_STEP RO, CON62[3], Cyton-CXP, Axion-CL

This bit reflects the real-time state of the board's scan step circuitry output (from the

quadrature encoder circuit).

**RD\_SW\_TRIG** RO, CON62[4], Cyton-CXP, Axion-CL

This bit reflects the real-time state of the board's software trigger.

**RD\_ENCA\_TTL** RO, CON62[5], Cyton-CXP, Axion-CL

This bit reflects the real-time state of the board's TTL encoder A input.

**RD\_ENCA\_DIF** RO, CON62[6], Cyton-CXP, Axion-CL

This bit reflects the real-time state of the board's differential encoder A input.

**RD\_ENCA\_VFG0** RO, CON62[7], Cyton-CXP, Axion-CL

This bit reflects the real-time state of VFG0's selected encoder A signal.

**RD\_ENCA\_SW** RO, CON62[8], Cyton-CXP, Axion-CL

This bit reflects the real-time state of the board's software encoder A.

**RD\_ENCB\_TTL** RO, CON62[9], Cyton-CXP, Axion-CL

This bit reflects the real-time state of the board's TTL encoder B input.

CON62 The Axion-CL

**RD\_ENCB\_DIF** RO, CON62[10], Cyton-CXP, Axion-CL

This bit reflects the real-time state of the board's differential encoder B input.

RD\_ENCB\_VFG0 RO, CON62[11], Cyton-CXP, Axion-CL

This bit reflects the real-time state of VFG0's selected encoder B signal.

RD\_ENCB\_SW RO, CON62[12], Cyton-CXP, Axion-CL

This bit reflects the real-time state of the board's software encoder B.

**RD\_BUTTON** RO, CON62[13], Cyton-CXP, Axion-CL

This bit reflects the real-time state of the board's button input.

RD\_CXP\_IO\_IN RO, CON62[23..16], Cyton-CXP, Axion-CL

These bits reflects the real-time state of board's 8 CXP general purpose input signals coming from the camera.

3

**RD\_CXP\_TRIG\_** RO, CON62[24], Cyton-CXP, Axion-CL

IN

This bit reflects the real-time state of the CXP trigger signal coming from the camera.

**EN\_TRIG** R/W, CON62[25], Cyton-CXP, Axion-CL

This bit is used to enable the selected trigger..

**EN ENCA** R/W, CON62[26], Cyton-CXP, Axion-CL

This bit is used to enable the selected encoder A.

**EN\_ENCB** R/W, CON62[27], Cyton-CXP, Axion-CL

This bit is used to enable the selected encoder B.

**RD\_ENCB**\_ RO, CON62[29], Cyton-CXP, Axion-CL **SELECTED** 

The bit reflects the real-time status of the board's select encoder B input.

AXN-6-8 BitFlow, Inc. Version A.0

**RD\_ENCA**RO, CON62[30], Cyton-CXP, Axion-CL **SELECTED** 

The bit reflects the real-time status of the board's selected encoder A input.

RD\_TRIG\_ SELECTED RO, CON62[31], Cyton-CXP, Axion-CL

The bit reflects the real-time status of the board's selected trigger input.

CON63 The Axion-CL

## 6.5 CON63

| Bit | Name     |
|-----|----------|
| 0   | SEL_TRIG |
| 1   | SEL_TRIG |
| 2   | SEL_TRIG |
| 3   | SEL_TRIG |
| 4   | SEL_TRIG |
| 5   | SEL_TRIG |
| 6   | SEL_ENCA |
| 7   | SEL_ENCA |
| 8   | SEL_ENCA |
| 9   | SEL_ENCA |
| 10  | SEL_ENCA |
| 11  | SEL_ENCA |
| 12  | SEL_ENCB |
| 13  | SEL_ENCB |
| 14  | SEL_ENCB |
| 15  | SEL_ENCB |
| 16  | SEL_ENCB |
| 17  | SEL_ENCB |
| 18  | SEL_CC1  |
| 19  | SEL_CC1  |
| 20  | SEL_CC1  |
| 21  | SEL_CC1  |
| 22  | SEL_CC2  |
| 23  | SEL_CC2  |
| 24  | SEL_CC2  |
| 25  | SEL_CC2  |
| 26  | Reserved |
| 27  | Reserved |
| 28  | SEL_LED  |
| 29  | SEL_LED  |
| 30  | SEL_LED  |
| 31  | SEL_LED  |
|     |          |

AXN-6-10 BitFlow, Inc. Version A.0

## **SEL\_TRIG** R/W, CON63[5..0], Cyton-CXP, Axion-CL

Selects the source of the trigger.

| SEL_TRIG     | Source                                          |
|--------------|-------------------------------------------------|
| 0 (000000b)  | Forced low                                      |
| 1 (000001b)  | Forced high                                     |
| 2 (000010b)  | This VFG's differential trigger VFGx_TRIGGER=/- |
| 3 (000011b)  | This VFG's TTL trigger VFGx_TRIGGER_TTL         |
| 4 (000100b)  | Selected trigger from VFG0, VFG0_TRIG_SEL       |
| 5 (000101b)  | This VFG's NTG or TS, VFGx_NTG, VFGx_TS         |
| 6 (000110b)  | Button                                          |
| 7 (000111b)  | The camera's CXP trigger, VFGx_CXP_TRIG         |
| 8 (001000b)  | This VFG's software trigger, SW_TRIG            |
| 9 (001001b)  | This VFG's scan step circuit                    |
| 10 (001010b) | VFG0's NTG or TS, VFG0_NTG or VFG0_TS           |
| 11-27        | Reserved                                        |
| 28 to 39     | BOX_IN_TTL_0 to BOX_IN_TTL_11                   |
| 40 to 51     | BOX_IN_DIF_0 to BOX_IN_DIF_11                   |
| 52 to 63     | BOS_IN_OPT_0 to BOX_IN_OPT_11                   |

## SEL\_ENCA

R/W, CON63[11..6], Cyton-CXP, Axion-CL

Selects the source of encoder A.

| SEL_ENCA    | Source                                         |
|-------------|------------------------------------------------|
| 0 (000000b) | Forced low                                     |
| 1 (000001b) | Forced high                                    |
| 2 (000010b) | This VFG's differential encoder A VFGx_ENCA=/- |
| 3 (000011b) | This VFG's TTL encoder A VFGx_ENCA_TTL         |
| 4 (000100b) | Selected encoder A from VFG0, VFG0_ENCA_SEL    |
| 5 (000101b) | This VFG's NTG or TS, VFGx_NTG, VFGx_TS        |
| 6 (000110b) | Button                                         |
| 7 (000111b) | The camera's CXP trigger, VFGx_CXP_TRIG        |
| 8 (001000b) | This VFG's software encoder A, SW_ENCA         |

CON63 The Axion-CL

| SEL_ENCA    | Source                                |
|-------------|---------------------------------------|
| 9 (001001b) | VFG0's NTG or TS, VFG0_NTG or VFG0_TS |
| 10-27       | Reserved                              |
| 28 to 39    | BOX_IN_TTL_0 to BOX_IN_TTL_11         |
| 40 to 51    | BOX_IN_DIF_0 to BOX_IN_DIF_11         |
| 52 to 63    | BOS_IN_OPT_0 to BOX_IN_OPT_11         |

# SEL\_ENCB

R/W, CON63[17..12], Cyton-CXP, Axion-CL

Selects the source of encoder B.

| SEL_ENCB    | Source                                         |
|-------------|------------------------------------------------|
| 0 (000000b) | Forced low                                     |
| 1 (000001b) | Forced high                                    |
| 2 (000010b) | This VFG's differential encoder B VFGx_ENCB=/- |
| 3 (000011b) | This VFG's TTL encoder B VFGx_ENCB_TTL         |
| 4 (000100b) | Selected encoder B from VFG0, VFG0_ENCB_SEL    |
| 5 (000101b) | This VFG's NTG or TS, VFGx_NTG, VFGx_TS        |
| 6 (000110b) | Button                                         |
| 7 (000111b) | The camera's CXP trigger, VFGx_CXP_TRIG        |
| 8 (001000b) | This VFG's software encoder B, SW_ENCB         |
| 9 (001001b) | VFG0's NTG or TS, VFG0_NTG or VFG0_TS          |
| 10-27       | Reserved                                       |
| 28 to 39    | BOX_IN_TTL_0 to BOX_IN_TTL_11                  |
| 40 to 51    | BOX_IN_DIF_0 to BOX_IN_DIF_11                  |
| 52 to 63    | BOS_IN_OPT_0 to BOX_IN_OPT_11                  |

AXN-6-12 BitFlow, Inc. Version A.0

## **SEL\_CC1** R/W, CON63[21..18], Cyton-CXP, Axion-CL

Selects the source of CC1.

| SEL_CC1    | Source                 |
|------------|------------------------|
| 0 (0000b)  | Forced low             |
| 1 (0001b)  | Forced high            |
| 2 (0010b)  | CT0 (from CTabs or TS) |
| 3 (0011b)  | CT1 (from CTabs or TS) |
| 4 (0100b)  | CT2 (from CTabs or TS) |
| 5 (0101b)  | CT3 (from CTabs or TS) |
| 6 (0110b)  | VFGx_TRIG_SEL          |
| 7 (0111b)  | VFGx_ENCA_SEL          |
| 8 (1000b)  | VFGx_ENCB_SEL          |
| 9 (1001b)  | VFG0_CT0               |
| 10 (1010b) | VFG0_CT1               |
| 11 (1011b) | VFG0_CT2               |
| 12 (1100b) | VFG0_CT3               |
| 13 (1101b) | VFGx_ENCDIV_SEL        |
| 14 (1110b) | VFGx_ENCQ_SEL          |

## **SEL\_CC2** R/W, CON63[25..22], Cyton-CXP, Axion-CL

Selects the source of CC2.

| SEL_CC1   | Source                 |
|-----------|------------------------|
| 0 (0000b) | Forced low             |
| 1 (0001b) | Forced high            |
| 2 (0010b) | CT0 (from CTabs or TS) |
| 3 (0011b) | CT1 (from CTabs or TS) |
| 4 (0100b) | CT2 (from CTabs or TS) |
| 5 (0101b) | CT3 (from CTabs or TS) |
| 6 (0110b) | VFGx_TRIG_SEL          |
| 7 (0111b) | VFGx_ENCA_SEL          |
| 8 (1000b) | VFGx_ENCB_SEL          |

CON63 The Axion-CL

| SEL_CC1    | Source          |
|------------|-----------------|
| 9 (1001b)  | VFG0_CT0        |
| 10 (1010b) | VFG0_CT1        |
| 11 (1011b) | VFG0_CT2        |
| 12 (0101b) | VFG0_CT3        |
| 14 (1110b) | VFGx_ENCDIV_SEL |
| 15 (1111b) | VFGx_ENCQ_SEL   |

# **SEL\_LED** R/W, CON63[31..28], Cyton-CXP, Axion-CL

Selects the source of the LED. The LED receives a 1/2 second pulse every time the selected event asserts.

| CEL CC4    | •                                    |
|------------|--------------------------------------|
| SEL_CC1    | Source                               |
| 0 (0000b)  | Board emits an interrupt to the host |
| 1 (0001b)  | VFGx_TRIG_SEL                        |
| 2 (0010b)  | VFG0_TRIG_SEL                        |
| 3 (0011b)  | Button                               |
| 4 (0100b)  | FVAL from camera                     |
| 5 (0101b)  | VAW                                  |
| 6 (0110b)  | VWIN                                 |
| 7 (0111b)  | CC1                                  |
| 8 (1000b)  | CC2                                  |
| 9 (1001b)  | CC3                                  |
| 10 (1010b) | CC4                                  |
| 11 (1011b) | VFGx_NTG or VFGx_TS                  |
| 12 (1100b) | VFG0_NTG or VFG0_TS                  |
| 13 (1101b) | AQSTAT[1]                            |
| 14 (1110b) | Overstep, OVS                        |
| 15 (1111b) | Reserved                             |

AXN-6-14 BitFlow, Inc. Version A.0

# 6.6 CON64

| Bit | Name             |
|-----|------------------|
| 0   | SEL_CC3          |
| 1   | SEL_CC3          |
| 2   | SEL_CC3          |
| 3   | SEL_CC3          |
| 4   | SEL_CC4          |
| 5   | SEL_CC4          |
| 6   | SEL_CC4          |
| 7   | SEL_CC4          |
| 8   | SEL_BOX_OUT_TTL  |
| 9   | SEL_BOX_OUT_DIF  |
| 10  | SEL_BOX_OUT_OPTO |
| 11  | Reserved         |
| 12  | Reserved         |
| 13  | TRIGPOL          |
| 14  | ENCA_POL         |
| 15  | ENCB_POL         |
| 16  | GPOUT0           |
| 17  | GPOUT1           |
| 18  | GPOUT2           |
| 19  | GPOUT3           |
| 20  | GPOUT4           |
| 21  | GPOUT5           |
| 22  | GPOUT6           |
| 23  | GPOUT7           |
| 24  | GPOUT8           |
| 25  | GPOUT9           |
| 26  | GPOUT10          |
| 27  | GPOUT11          |
| 28  | LED_RED          |
| 29  | LED_ORANGE       |
| 30  | LED_GREEN        |
| 31  | LED_BLUE         |

CON64 The Axion-CL

## **SEL\_CC3** R/W, CON64[3..0], Cyton-CXP, Axion-CL

Selects the source of CC3.

| SEL_CC1    | Source                 |
|------------|------------------------|
| 0 (0000b)  | Forced low             |
| 1 (0001b)  | Forced high            |
| 2 (0010b)  | CT0 (from CTabs or TS) |
| 3 (0011b)  | CT1 (from CTabs or TS) |
| 4 (0100b)  | CT2 (from CTabs or TS) |
| 5 (0101b)  | CT3 (from CTabs or TS) |
| 6 (0110b)  | VFGx_TRIG_SEL          |
| 7 (0111b)  | VFGx_ENCA_SEL          |
| 8 (1000b)  | VFGx_ENCB_SEL          |
| 9 (1001b)  | VFG0_CT0               |
| 10 (1010b) | VFG0_CT1               |
| 11 (1011b) | VFG0_CT2               |
| 12 (0101b) | VFG0_CT3               |
| 14 (1110b) | VFGx_ENCDIV_SEL        |
| 15 (1111b) | VFGx_ENCQ_SEL          |

# **SEL\_CC4** R/W, CON64[7..4], Cyton-CXP, Axion-CL

Selects the source of CC4.

| SEL_CC1   | Source                 |
|-----------|------------------------|
| 0 (0000b) | Forced low             |
| 1 (0001b) | Forced high            |
| 2 (0010b) | CT0 (from CTabs or TS) |
| 3 (0011b) | CT1 (from CTabs or TS) |
| 4 (0100b) | CT2 (from CTabs or TS) |
| 5 (0101b) | CT3 (from CTabs or TS) |
| 6 (0110b) | VFGx_TRIG_SEL          |
| 7 (0111b) | VFGx_ENCA_SEL          |
| 8 (1000b) | VFGx_ENCB_SEL          |

AXN-6-16 BitFlow, Inc. Version A.0

| SEL_CC1    | Source          |
|------------|-----------------|
| 9 (1001b)  | VFG0_CT0        |
| 10 (1010b) | VFG0_CT1        |
| 11 (1011b) | VFG0_CT2        |
| 12 (0101b) | VFG0_CT3        |
| 14 (1110b) | VFGx_ENCDIV_SEL |
| 15 (1111b) | VFGx_ENCQ_SEL   |

# TTL

**SEL\_BOX\_OUT\_** R/W, CON64[8], Cyton-CXP, Axion-CL

Selects the source for the IOBOX TTL outputs.

| SEL_BOX_OUT_TTL | Meaning                                              |
|-----------------|------------------------------------------------------|
| 0               | IOBOX TTL outputs are driven GPOUT0 to GPOUT11       |
| 1               | IOBOX TTL outputs are driven by VFG0_CC1 to VFG3_CC3 |

#### SEL\_BOX\_OUT\_ DIF

R/W, CON64[9], Cyton-CXP, Axion-CL

Selects the source for the IOBOX differential outputs.

| SEL_BOX_OUT_DIF | Meaning                                                       |
|-----------------|---------------------------------------------------------------|
| 0               | IOBOX differential outputs are driven GPOUT0 to GPOUT11       |
| 1               | IOBOX differential outputs are driven by VFG0_CC1 to VFG3_CC3 |

# **OPTO**

**SEL\_BOX\_OUT\_** R/W, CON64[10], Cyton-CXP, Axion-CL

Selects the source for the IOBOX opto-isolated outputs.

| SEL_BOX_OUT_DIF | Meaning                                               |
|-----------------|-------------------------------------------------------|
| 0               | IOBOX opto outputs are driven GPOUT0 to GPOUT11       |
| 1               | IOBOX opto outputs are driven by VFG0_CC1 to VFG3_CC3 |

CON64 The Axion-CL

#### TRIGPOL R/W, CON64[13], Cyton-CXP, Axion-CL

Selects the edge of the trigger signal the corresponds to its assertion.

| TRIGPOL | Meaning                          |
|---------|----------------------------------|
| 0       | Trigger asserted on rising edge  |
| 1       | Trigger asserted on falling edge |

#### **ENCA\_POL**

R/W, CON64[14], Cyton-CXP, Axion-CL

Selects the edge of encoder A signal the corresponds to its assertion.

| ENCA_POL | Meaning                            |
|----------|------------------------------------|
| 0        | Encoder A asserted on rising edge  |
| 1        | Encoder A asserted on falling edge |

#### **ENCB\_POL**

R/W, CON64[15], Cyton-CXP, Axion-CL

Selects the edge of encoder B signal the corresponds to its assertion.

| ENCB_POL | Meaning                            |
|----------|------------------------------------|
| 0        | Encoder B asserted on rising edge  |
| 1        | Encoder B asserted on falling edge |

#### **GPOUTO**

R/W, CON64[16], Cyton-CXP, Axion-CL

General purpose output bit 0.

#### **GPOUT1**

R/W, CON64[17], Cyton-CXP, Axion-CL

General purpose output bit 1.

#### **GPOUT2**

R/W, CON64[18], Cyton-CXP, Axion-CL

General purpose output bit 2.

#### **GPOUT3**

R/W, CON64[19], Cyton-CXP, Axion-CL

General purpose output bit 3.

**GPOUT4** R/W, CON64[20], Cyton-CXP, Axion-CL

General purpose output bit 4.

**GPOUT5** R/W, CON64[21], Cyton-CXP, Axion-CL

General purpose output bit 5.

**GPOUT6** R/W, CON64[22], Cyton-CXP, Axion-CL

General purpose output bit 6.

**GPOUT7** R/W, CON64[23], Cyton-CXP, Axion-CL

General purpose output bit 7.

**GPOUT8** R/W, CON64[24], Cyton-CXP, Axion-CL

General purpose output bit 8.

**GPOUT9** R/W, CON64[25], Cyton-CXP, Axion-CL

General purpose output bit 9.

**GPOUT10** R/W, CON64[26], Cyton-CXP, Axion-CL

General purpose output bit 10.

**GPOUT11** R/W, CON64[27], Cyton-CXP, Axion-CL

General purpose output bit 11.

**LED\_RED** R/W, CON64[28], Cyton-CXP, Axion-CL

Setting this bit to 1 turns the red LED on.

**LED\_ORANGE** R/W, CON64[29], Cyton-CXP, Axion-CL

Setting this bit to 1 turns the orange LED on.

CON64 The Axion-CL

**LED\_GREEN** R/W, CON64[30], Cyton-CXP, Axion-CL

Setting this bit to 1 turns the green LED on.

AXN-6-20 BitFlow, Inc. Version A.0

# 6.7 ADDR\_TRIG\_FILTER

| Bit | Name        |
|-----|-------------|
| 0   | TRIG_FILTER |
| 1   | TRIG_FILTER |
| 2   | TRIG_FILTER |
| 3   | TRIG_FILTER |
| 4   | TRIG_FILTER |
| 5   | TRIG_FILTER |
| 6   | TRIG_FILTER |
| 7   | TRIG_FILTER |
| 8   | TRIG_FILTER |
| 9   | TRIG_FILTER |
| 10  | TRIG_FILTER |
| 11  | TRIG_FILTER |
| 12  | TRIG_FILTER |
| 13  | TRIG_FILTER |
| 14  | TRIG_FILTER |
| 15  | TRIG_FILTER |
| 16  | TRIG_FILTER |
| 17  | TRIG_FILTER |
| 18  | Reserved    |
| 19  | Reserved    |
| 20  | Reserved    |
| 21  | Reserved    |
| 22  | Reserved    |
| 23  | Reserved    |
| 24  | Reserved    |
| 25  | Reserved    |
| 26  | Reserved    |
| 27  | Reserved    |
| 28  | Reserved    |
| 29  | Reserved    |
| 30  | Reserved    |
| 31  | Reserved    |

ADDR TRIG FILTER The Axion-CL

### **TRIG\_FILTER** RO, ADDR\_TRIG\_FILTER[17..0], Cyton-CXP, Axion-CL

The trigger circuit includes a programmable noise filter. The value of this register controls the size of the noise pulse that will be considered noised and will be filtered out. Any pulses over this size will be consider signal. The units of this register are 4 nanoseconds. If this register is programmed to 0, nothing will be filter. If this register is programmed to 0x3ffff, pulses of up to 1 millisecond will be removed.

AXN-6-22 BitFlow, Inc. Version A.0

# 6.8 ADDR\_ENCA\_FILTER

| Bit | Name        |
|-----|-------------|
| 0   | ENCA_FILTER |
| 1   | ENCA_FILTER |
| 2   | ENCA_FILTER |
| 3   | ENCA_FILTER |
| 4   | ENCA_FILTER |
| 5   | ENCA_FILTER |
| 6   | ENCA_FILTER |
| 7   | ENCA_FILTER |
| 8   | ENCA_FILTER |
| 9   | ENCA_FILTER |
| 10  | ENCA_FILTER |
| 11  | ENCA_FILTER |
| 12  | ENCA_FILTER |
| 13  | ENCA_FILTER |
| 14  | ENCA_FILTER |
| 15  | ENCA_FILTER |
| 16  | ENCA_FILTER |
| 17  | ENCA_FILTER |
| 18  | Reserved    |
| 19  | Reserved    |
| 20  | Reserved    |
| 21  | Reserved    |
| 22  | Reserved    |
| 23  | Reserved    |
| 24  | Reserved    |
| 25  | Reserved    |
| 26  | Reserved    |
| 27  | Reserved    |
| 28  | Reserved    |
| 29  | Reserved    |
| 30  | Reserved    |
| 31  | Reserved    |

ADDR ENCA FILTER The Axion-CL

### **ENCA\_FILTER** RO, ADDR\_ENCA\_FILTER[17..0], Cyton-CXP, Axion-CL

The encoder A circuit includes a programmable noise filter. The value of this register controls the size of the noise pulse that will be considered noised and will be filtered out. Any pulses over this size will be consider signal. The units of this register are 4 nanoseconds. If this register is programmed to 0, nothing will be filter. If this register is programmed to 0x3ffff, pulses of up to 1 millisecond will be removed.

AXN-6-24 BitFlow, Inc. Version A.0

# 6.9 ADDR\_ENCB\_FILTER

| Bit | Name        |
|-----|-------------|
| 0   | ENCB_FILTER |
| 1   | ENCB_FILTER |
| 2   | ENCB_FILTER |
| 3   | ENCB_FILTER |
| 4   | ENCB_FILTER |
| 5   | ENCB_FILTER |
| 6   | ENCB_FILTER |
| 7   | ENCB_FILTER |
| 8   | ENCB_FILTER |
| 9   | ENCB_FILTER |
| 10  | ENCB_FILTER |
| 11  | ENCB_FILTER |
| 12  | ENCB_FILTER |
| 13  | ENCB_FILTER |
| 14  | ENCB_FILTER |
| 15  | ENCB_FILTER |
| 16  | ENCB_FILTER |
| 17  | ENCB_FILTER |
| 18  | Reserved    |
| 19  | Reserved    |
| 20  | Reserved    |
| 21  | Reserved    |
| 22  | Reserved    |
| 23  | Reserved    |
| 24  | Reserved    |
| 25  | Reserved    |
| 26  | Reserved    |
| 27  | Reserved    |
| 28  | Reserved    |
| 29  | Reserved    |
| 30  | Reserved    |
| 31  | Reserved    |

ADDR ENCB FILTER The Axion-CL

### **ENCB\_FILTER** RO, ADDR\_ENCB\_FILTER[17..0], Cyton-CXP, Axion-CL

The encoder B circuit includes a programmable noise filter. The value of this register controls the size of the noise pulse that will be considered noised and will be filtered out. Any pulses over this size will be consider signal. The units of this register are 4 nanoseconds. If this register is programmed to 0, nothing will be filter. If this register is programmed to 0x3ffff, pulses of up to 1 millisecond will be removed.

AXN-6-26 BitFlow, Inc. Version A.0

Encoder Divider Introduction

# **Encoder Divider**

# Chapter 7

### 7.1 Introduction

This section covers the encoder divider which supported on the all of BitFlow's modern frame grabber families. The purpose of Encoder Divider is to provide the ability to use an encoder running at one rate to drive a line scan camera at a different rate. This circuit is only useful for line scan cameras. The Encoder Divider can scale up or down the incoming encoder frequency. The encoder divider is fully programmable and is easily controlled from software and/or from camera configuration files.

The factor used to scaled the incoming encoder frequency does not have to be a whole number. For example, the encoder could be scaled by 0.03448 or 4.2666). Of course not all ration numbers in the available scaling range can be selected (t are an infinite number of them). However, a useful selection of values is available which should support most applications.

The Encoder Divider circuit takes as its input the selected encoder input. The output of the encoder divider drives the same parts of the board the normal encoder usually does. The actual circuit(s) being driven depends on how the board is programmed.

Encoder Divider Details The Axion-CL

### 7.2 Encoder Divider Details

#### 7.2.1 Formula

The following formula shows the equation used to scale the encoming encoder rate into the camera's line rate:

$$F_{out} = F_{in} \frac{2^N}{M}$$

W:

Fout = The frequency used to driver the camera or the NTG or the CTabs

Fin = The encoder (input) frequency

 $N = An integer between 0 and 6 (set by the register ENC_DIV_N)$ 

M = An integer between 1 and 1023 (set by the register ENC\_DIV\_M)

The above formula provides an effective scaling factor from 0.001 (N = 0, M = 1023) to 64 (N = 6, M = 1). Not every scaling factor can be achieved between these two extremes, and the scaling factors are not evenly distributed. However, a scaling factor can be generally found that meets the requirements of most applications.

# 7.2.2 Example

Let's assume that the encoder frequency (Fin) is 10 KHz and that we need an output (Fout) of  $\sim$ 30 KHz. This means that we need to multiply by 3. Set N = 6 and M = 21. This will a scaling factor of 3.048. The result is an effective line rate of 30.48 KHz.

#### 7.2.3 Restrictions

Because the encoder divider uses a digital PLL run by a high frequency clock, not all encoder input frequencies can be accurately scaled. The PLL has been designed to work in most machine visions applications. Support, tfore, is provided for the following input frequency range:

Minimum input encoder frequency: 1.6 KHz Maximum input encoder frequency: 300 KHz Encoder Divider Encoder Divider Details

### 7.2.4 PLL Locking

The encoder divider achieves its scaling using a PLL. By default the output waveform is locked to the input waveform. However, this locking can result in a small amount of jitter. To reduce the jitter, the output waveform can be run open loop. This mode is accessed by setting the register ENC\_DIV\_OPEN\_LOOP to 1.

### 7.2.5 Handling Encoder Slow Down or Stopping

On some machine vision systems, the encoder is attached to a mechanism that may slow and/or stop. Any PLL has a limited range that it can track (based on the PLL master clock), outside of this range, the output signal can become unpredictable. The Encoder Divider circuit's master clock is 50 MHz, which makes the minimum frequency that it can accurately track around 1.6 KHz. In order to avoid this situation and handle encoder slow down/stop gracefully, the encoder divider has has limiting circuit that can be run in one of two different mode described in the following two sections.

#### Slow Tracking Mode (ENC\_DIC\_FORCE\_DC = 0)

In this mode, when the input frequency goes below the minimum of 1.6 KHz, the Encoder Divider circuit's output will continue to track the input, but the output frequency will become simple divider on the input frequency. In this mode the output will track the input using the following formula (the variables are the same as in Section 7.2.1)

$$F_{out} = \frac{F_{in}}{4M}$$

#### DC Mode (ENC\_DIV\_FORCE\_DC = 1)

In this mode, the Fin goes below 1.6 KHz, Fout will goes to DC. This means that when the input frequency goes below the minimum the camera will be frozen, acquisition will stop. The board will stay in this state until Fin goes above 1.6 KHz. This is useful when the encoder is being driven by a stage that is traveling back and forth. At both ends of travel when the stage changes directions, the board will not acquire.

# 7.3 Encoder Divider Control Registers

The following table summarizes the registers:

Table 7-1 Encoder Divider Registers

| Name              | Purpose                                                                                                                                                                       |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ENC_DIV_M         | This controls the M factor in the Encoder Divider equation (see Section 7.2.1)                                                                                                |
| ENC_DIV_N         | The controls the N factor the Encoder Divider equation                                                                                                                        |
| ENC_DIV_FORCE_DC  | Controls the behavior when Fin falls below the minimum. 0 = Output runs in simple divider mode. 1 = Output goes to DC.                                                        |
| ENC_DIV_OPEN_LOOP | Controls whether the output signal phase of the Encoder Divider is lock to the intput or is allowed to free run. 0 = Output phased locked to input. 1 = Ouput runs open loop. |
| ENC_DIV_FCLK_SEL  | Reserved for future support for alternate Encoder<br>Divider PLL Master clock frequencies. Currently must<br>be set to 0, which selects 50 MHz clock.                         |

See Chapter 9 for details on the registers needed to control the encoder divider system.

AXN-7-4 BitFlow, Inc. Version A.0

Quadrature Encoder Introduction

# Quadrature Encoder

# Chapter 8

### 8.1 Introduction

This section discusses support for quadrature encoders. A quadrature encoder is an encoder that outputs two signals A and B. Both signals are used as a line trigger. However, the signals are 90 degrees out of phase. By comparing the A and B signals, the direction of the encoder motion can be determined. T are a number of ways that quadrature encoders can be used to control acquisition. The following sections cover all of the support methods.

Most of the quadrature encoder system is based around a 24-bit counter. This normally starts at zero and then counts up or down every time the encoder moves. The counter can be observed at any time via the QENC\_COUNT register. This registers is the heart of the encoder system. For example, triggers values can be programmed to start and end acquisition of lines. Also, as the counter tracks the motion of the stage attached to the encoder exactly, the system can be programmed to only acquire forward only or backward only stage movements. The system can be programmed to only acquire one line for each encoder count that corresponds to a physical location on the stage. The encoder counter can be used in many different ways, described in more details below.

### 8.1.1 Simple Encoder Mode

The most basic method of using a quadrature encoder is to use it like a standard signal phase encoder. In this mode, the quadrature encoder provides a higher resolution signal, as both the A and B signals can be used to trigger lines. Also, by setting QENC\_DECODE = 1, both the rising and the falling edges of both the A and B signals are used to trigger lines, providing a 4x increase in resolution over a signal phase encoder.

In this mode, every encoder edge triggers a line, the direction information from the encoder is ignored.

### 8.1.2 Positive or Negative Only Acquisition

The board can be programmed to only acquired lines when the encoder moves forward (increase the encoder count in a positive direction) or moves backwards (decrease the encoder count in a negative direction). This mode is useful in situations w a stage is moving back and forth, and lines need only be acquired if the stage is moving in one direction only. The direction of acquisition is controlled by the QENC\_AQ\_DIR register.

Introduction The Axion-CL

#### 8.1.3 Interval Mode

Often in situations when a stage is moving back and forth, acquisition is only required over a subsection of the total stage range. Interval mode has been designed for these situations. When the board is in interval mode, it only acquires lines when the encoder counter is between a lower limit and an upper limit. If the counter is outside these limits, lines are not acquired.

To use interval mode, set QENC\_INTRVL\_MODE = 1, and program QENC\_INTRVL\_LL and QENC\_INTRVL\_UL to the encoder ranges that bracket the section of your stage range that you wish to acquire. Interval mode can be used in conjunction with QENC\_AQ\_DIR to acquire lines passing over the interval in the positive direction, the negative direction or both directions.

### 8.1.4 Re-Acquisition Prevention

Encoders are usually connected to mechanical systems which do not always move smoothly. Because of these imperfections, t can be "jitter" in the quadrature encoder signal. This jitter is not an electrical imperfection, but represent the reality of the mechanical system vibrating, jumping, bouncing, etc. If these imperfections occur during the period of time w lines are being acquired, the image will be distorted. Lines on the object can be acquired more than once as the stage jitters. To prevent reacquisition of lines, a circuit has been added to the quadrature encoder system that can prevent any line from being acquired more than once. To enable this mode, set QENC NO REAQ = 1.

# 8.1.5 Scan Step Mode

The encoder can also be used to trigger acquisition of full frames from an area scan camera. The idea is that every N lines, a trigger is issued to the board, which causes acquisition of a frame. This can be used, for example, with a linear stage, w an image is needed in steps across the range of the stage. This mode is enable by setting SCAN\_STEP\_TRIG = 1, and programming SCAN\_STEP to the number of encoder counts per trigger.

### 8.1.6 Combining Modes

All of the modes above can be combined to support complicated encoder requirements. For example, the board can be programmed to acquire an interval in the positive direction only, with no lines being reacquired. Many combinations are possible.

### 8.1.7 Control Registers

See Chapter 9 for the registers needed to control the quadrature encoder system.

Quadrature Encoder Introduction

### 8.1.8 Observability

The status of the quadrature encoder system can be observed at any time. Shown in Table 8-1are all the registers that can be used.:

Table 8-1 Observability Registers.

| Register       | Meaning                                |
|----------------|----------------------------------------|
| QENC_COUNT     | Encoder counter                        |
| QENC_PHASEA    | Phase of input A                       |
| QENC_PHASEB    | Phase of input B                       |
| QENC_DIR       | Direction of encoder                   |
| QENC_INTRVL_IN | Interval status                        |
| QENC_NEW_LINES | Indicates new lines are being acquired |

### 8.1.9 Electrical Connections

Both TTL and LVDS (differential) quadrature encoders are supported. TTL connections are shown in Table 8-2 and LVDS connections are shown in Table 8-3.

Table 8-2 TTL Quadrature Encoder Connections

| Encoder | Frame Grabber     |
|---------|-------------------|
| Α       | VFGx_ENCODERA_TTL |
| В       | VFGx_ENCODERB_TTL |
| Ground  | GND               |

Table 8-3 LVDS Quadrature Encoder Connections

| Encoder | Frame Grabber  |
|---------|----------------|
| A+      | VFGx_ENCODERA+ |
| A-      | VFGx_ENCODERA- |
| B+      | VFGx_ENCODERB+ |
| B-      | VFGx_ENCODERB- |

Note: VFGx - refers to the VFG number that you wish to connect to. For example, if you want to connect a TLL A output to VFG 0, then you would use VFG0\_ENCODERA\_TTL.

# 8.2 Understanding Stage Movement vs. Quadrature Encoder Modes

The quadrature encoder system has many modes that can be used in various combinations. These combinations are easier to understand through a few simple illustrations. Figure 8-1 shows the basic Encoder Count vs. Time graph and how it corresponds to stage movement. Keep in mind that the encoder could be attached to any mechanical system, however, a back and forth stage is a simple way to illustrate these modes.

In Figure 8-1 you can see as the stage moves back and forth, the encoder counts up and down. Further, in this example we assume QENC\_AQ\_DIR = 1, which tells the system to only acquire when the encoder counter is moving in the positive direction. This is illustrated by solid lines in the positive direction and dashed lines in the negative direction.



Corresponding Encoder Count vs. Time



Figure 8-1 Encoder Count vs Time

Figure 8-2 shows all of the major quadrature encoder modes.



Figure 8-2 Quadrature Encoder Modes vs. Acquisition

# Quadrature Encoder and Divider Registers

# Chapter 9

### 9.1 Introduction

This section enumerates the registers used to control the boards quadrature encoder circuit and encoder divider circuit.

CON65 Register The Axion-CL

# 9.2 CON65 Register

| Bit | Name             |
|-----|------------------|
| 0   | SEL_ENCQ         |
| 1   | SEL_ENCDIV_INPUT |
| 2   | SEL_ENCDIV       |
| 3   | ENC_DIV_N        |
| 4   | ENC_DIV_N        |
| 5   | ENC_DIV_N        |
| 6   | ENC_DIV_M        |
| 7   | ENC_DIV_M        |
| 8   | ENC_DIV_M        |
| 9   | ENC_DIV_M        |
| 10  | ENC_DIV_M        |
| 11  | ENC_DIV_M        |
| 12  | ENC_DIV_M        |
| 13  | ENC_DIV_M        |
| 14  | ENC_DIV_M        |
| 15  | ENC_DIV_M        |
| 16  | SCAN_STEP        |
| 17  | SCAN_STEP        |
| 18  | SCAN_STEP        |
| 19  | SCAN_STEP        |
| 20  | SCAN_STEP        |
| 21  | SCAN_STEP        |
| 22  | SCAN_STEP        |
| 23  | SCAN_STEP        |
| 24  | SCAN_STEP        |
| 25  | SCAN_STEP        |
| 26  | SCAN_STEP        |
| 27  | SCAN_STEP        |
| 28  | SCAN_STEP        |
| 29  | SCAN_STEP        |
| 30  | SCAN_STEP        |
| 31  | SCAN_STEP        |

AXN-9-2 BitFlow, Inc. Version A.0

#### SEL ENCQ

R/W, CON65[0], Cyton-CXP, Axion-CL

This bit selects which quadrature encoder circuit output will be used on this VFG.

| SEL_ENCQ | Meaning                                                   |
|----------|-----------------------------------------------------------|
| 0        | Select the output of this VFG's quadrature circuit output |
| 1        | Select the output of VFG0's quadrature circuit output     |

# SEL\_ENCDIV\_INPUT

R/W, CON65[1], Cyton-CXP, Axion-CL

This bit selects which input will driver the encoder divider circuit.

| SEL_EENC_DIV_<br>INPUT | Meaning                                            |
|------------------------|----------------------------------------------------|
| 0                      | VFGx_ENCA_SEL                                      |
| 1                      | The output of this VFG's quadrature circuit output |

#### SEL\_ENCDIV

R/W, CON65[2], Cyton-CXP, Axion-CL

This bit selects which encoder divider circuit output will be used on this VFG.

| SEL_ENCDIV | Meaning                                                |
|------------|--------------------------------------------------------|
| 0          | Select the output of this VFG's encoder divider output |
| 1          | Select the output of VFG0's encoder divider output     |

#### **ENC DIV N**

R/W, CON65[5..3], Cyton-CXP, Axion-CL

These bits set the N part of the encoder divider equation. See Section 7.1 for more information.

#### **ENC\_DIV\_M**

R/W, CON65[15..6], Cyton-CXP, Axion-CL

These bits set the N part of the encoder divider equation. See Section 7.1 for more information.

#### **SCAN\_STEP**

R/W, CON65[31..16], Cyton-CXP, Axion-CL

This bitfield controls the number of encoder pulses that must occur before a trigger is issued to the system. See SCAN\_STEP\_TRIG for more information. The Scan Step circuit takes into account the interval and re-acquisition functions.

CON66 Register The Axion-CL

# 9.3 CON66 Register

| Bit | Name             |
|-----|------------------|
| 0   | QENC_INTRVL_LL   |
| 1   | QENC_INTRVL_LL   |
| 2   | QENC_INTRVL_LL   |
| 3   | QENC_INTRVL_LL   |
| 4   | QENC_INTRVL_LL   |
| 5   | QENC_INTRVL_LL   |
| 6   | QENC_INTRVL_LL   |
| 7   | QENC_INTRVL_LL   |
| 8   | QENC_INTRVL_LL   |
| 9   | QENC_INTRVL_LL   |
| 10  | QENC_INTRVL_LL   |
| 11  | QENC_INTRVL_LL   |
| 12  | QENC_INTRVL_LL   |
| 13  | QENC_INTRVL_LL   |
| 14  | QENC_INTRVL_LL   |
| 15  | QENC_INTRVL_LL   |
| 16  | QENC_INTRVL_LL   |
| 17  | QENC_INTRVL_LL   |
| 18  | QENC_INTRVL_LL   |
| 19  | QENC_INTRVL_LL   |
| 20  | QENC_INTRVL_LL   |
| 21  | QENC_INTRVL_LL   |
| 22  | QENC_INTRVL_LL   |
| 23  | QENC_INTRVL_LL   |
| 24  | QENC_DECODE      |
| 25  | QENC_AQ_DIR      |
| 26  | QENC_AQ_DIR      |
| 27  | QENC_INTRVL_MODE |
| 28  | QENC_NO_REAQ     |
| 29  | QENC_DUAL_PHASE  |
| 30  | SCAN_STEP_TRIG   |
| 31  | QENC_RESET       |

AXN-9-4 BitFlow, Inc. Version A.0

#### QENC INTRVL LL

R/WR/W, CON66[23..0], Cyton-CXP, Axion-CL

This register contains the lower limit value that is used to start acquisition when the system is in interval mode (see QENC\_INTRVL\_MODE).

**QENC\_DECODE** R/W, CON66[24], Cyton-CXP, Axion-CL

This bit determines how often the quadrature counter is incremented.

| QENC_DECODE | Meaning                                                                                                                               |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 0           | Counter increments on the rising edge of input A and the rising edge of input B. This is also called "2x" modes.                      |
| 1           | Counter increments on both the rising and falling edge of A and both the rising and falling edge of B. This is also called "4x" mode. |

### QENC\_AQ\_DIR

R/W, CON66[26..25], Cyton-CXP, Axion-CL

This bit controls which quadrature encoder direction is used for acquisition.

| QENC_AQ_DIR | Meaning                                            |
|-------------|----------------------------------------------------|
| 0 (00b)     | Lines are acquired in both directions              |
| 1 (01b)     | Lines are acquired only in the positive direction. |
| 2 (10b)     | Lines are acquired only in the negative direction. |
| 3 (11b)     | Reserved                                           |

#### QENC\_INTRVL\_ MODE

R/W, CON66[27], Cyton-CXP, Axion-CL

When this bit is 1, interval mode is turned on. When interval mode is on, lines are only captured when the encoder counter is between the lower limit (set by QENC\_ INTRVL\_LL) and the upper limit (set by QENT\_INTRVL\_UL). If the counter is outside of this range, lines are not acquired. Whether lines are acquired as the counter increments through the interval, or decrements through the interval, or in both directions are controlled by QENC\_AQ\_DIR.

#### QENC NO REAQ

R/W, CON66[28], Cyton-CXP, Axion-CL

This bit controls how the quadrature encoder system handles the situation w the encoder does not smoothly increase (or decrease if QENC AQ DIR = 1). If t is "jitter" in the encoder signal, often caused by problems with the mechanical systems, it is possible for the board to acquire the same line or lines more than once as the

CON66 Register The Axion-CL

mechanical system backs up and moves forward (jitter). This re-acquisition can cause problems as the resulting images will have distortions and will not accurately represent the object in front of the camera.

Programming this bit to a 1 turns on the no-reacquisition circuit. This circuit eliminates this problem as each line in the image will only be acquired once, regardless of how much jitter occurs in the quadrature encoder input. The circuit does this by making sure that only one line is acquired for each encoder counter value. If the quadrature encoder backs up, and then moves forward, the board will not acquire lines until a new encoder counter value is reached.

This system handles any amount of jitter, regardless of how many times the counter passes through a value, or to what extremes the counter goes. New lines will only be acquired when new values are reached.

Once the entire frame has been acquired, the system must be reset. The system can always be reset by poking QENC\_RESET to 1. T are also ways that the system can automatically be reset, see QENC\_RESET\_MODE.

| QENC_NO_REAQ | Meaning                                                                                              |
|--------------|------------------------------------------------------------------------------------------------------|
| 0            | Lines are acquired every change in the encoder counter (as controlled by QENC_AQ_DIR)                |
| 1            | Lines are only acquired when the encoder counter reaches new values (also controlled by QENC_AQ_DIR) |

#### QENC\_DUAL\_ PHASE

R/W, CON66[29], Cyton-CXP, Axion-CL

This bit controls which type of encoder is attached.

| QENC_DUAL_PHASE | Meaning                            |
|-----------------|------------------------------------|
| 0               | A single phase encoder is attached |
| 1               | A quadrature encoder is attached   |

#### SCAN\_STEP\_ TRIG

R/W, CON66[30], Cyton-CXP, Axion-CL

The scan step circuit uses the encoder to generate a trigger to the system. The scan step trigger generates a trigger every N lines (N is set in the SCAN\_STEP register).

| SCAN_STEP_TRIG | Meaning                                  |
|----------------|------------------------------------------|
| 0              | Trigger comes of the normal source       |
| 1              | Trigger comes from the scan step circuit |

**QENC\_RESET** WO, CON66[31], Cyton-CXP, Axion-CL

Poking this bit to a 1 resets the entire quadrature encoder system.

CON67 Register The Axion-CL

# 9.4 CON67 Register

| Bit | Name              |
|-----|-------------------|
| 0   | QENC_INTRVL_UL    |
| 1   | QENC_INTRVL_UL    |
| 2   | QENC_INTRVL_UL    |
| 3   | QENC_INTRVL_UL    |
| 4   | QENC_INTRVL_UL    |
| 5   | QENC_INTRVL_UL    |
| 6   | QENC_INTRVL_UL    |
| 7   | QENC_INTRVL_UL    |
| 8   | QENC_INTRVL_UL    |
| 9   | QENC_INTRVL_UL    |
| 10  | QENC_INTRVL_UL    |
| 11  | QENC_INTRVL_UL    |
| 12  | QENC_INTRVL_UL    |
| 13  | QENC_INTRVL_UL    |
| 14  | QENC_INTRVL_UL    |
| 15  | QENC_INTRVL_UL    |
| 16  | QENC_INTRVL_UL    |
| 17  | QENC_INTRVL_UL    |
| 18  | QENC_INTRVL_UL    |
| 19  | QENC_INTRVL_UL    |
| 20  | QENC_INTRVL_UL    |
| 21  | QENC_INTRVL_UL    |
| 22  | QENC_INTRVL_UL    |
| 23  | QENC_INTRVL_UL    |
| 24  | QENC_REAQ_MODE    |
| 25  | QENC_REAQ_MODE    |
| 26  | QENC_RESET_REAQ   |
| 27  | ENC_DIV_FOURCE_DC |
| 28  | ENC_DIV_OPEN_LOOP |
| 29  | ENC_DIV_FCLK_SEL  |
| 30  | ENC_DIV_FCLK_SEL  |
| 31  | ENC_DIV_FCLK_SEL  |

AXN-9-8 BitFlow, Inc. Version A.0

#### QENC\_INTRVL\_ UL

R/W, CON67[23..0], Cyton-CXP, Axion-CL

This register contains the upper limit value that is used to start acquisition when the system is in interval mode (see QENC\_INTRVL\_MODE).

### QENC\_REAQ\_ MODE

R/W, CON67[25..24], Cyton-CXP, Axion-CL

This bit controls how the circuit that prevents re-acquisition from encoder jitter is reset. Re-acquisition is prevented by keeping a list of lines that have been acquired, and making sure that only lines that are not on the list are acquired. Once the entire frame is acquired, t must be some way to reset the list, otherwise no new lines will ever be acquired See QENC\_NO\_REAQ for more information.

The reset can be either automatic or manual. Manual modes require that the host application software poke the QENC\_RESET\_REAQ bit when the reset is desired. Automatic modes do not require host interaction, the reset will occur automatically when the specified conditions are met.

| QENC_REAQ_MODE | Mode      | Meaning                                                                                                                                                                                                                          |
|----------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 (00b)        | Manual    | Reset the list of acquired lines when QENC_RESET_REAQ is poked to 1.                                                                                                                                                             |
| 1 (01b)        | Automatic | Reset the list of lines when the encoder counter is outside of the interval set by the upper limit and lower limit. Whether the reset occurs above the upper limit or below the lower limit depends on the QENC_AQ_DIR register. |
| 2 (10b)        |           | Reserved                                                                                                                                                                                                                         |
| 3 (11b)        |           | Reserved                                                                                                                                                                                                                         |

#### QENC\_RESET\_ REAQ

WO, CON67[26], Cyton-CXP, Axion-CL

This register is used to reset the circuit that prevents the re-acquisition of lines when QENC\_NO\_REAQ is set to 1. Writing a 1 to this register deletes the list of acquired lines, thus next time the lines are passed over, they will be acquired again. Writing to this bit always resets the no re-acquisition circuit, regardless of the mode set by the QENC\_REAQ\_MODE. However, the register QENC\_REAQ\_MODE can be used to set the board in a mode w the no re-acquisition circuit is reset automatically every pass over the image.

### ENC\_DIV\_ FORCE\_DC

R/W, CON67[27], Cyton-CXP, Axion-CL

Setting this bit to 1 forces the encoder divider to output a DC signal when the input signal falls below a certain frequency.

CON67 Register The Axion-CL

ENC\_DIV\_ OPEN\_LOOP R/W, CON67[28], Cyton-CXP, Axion-CL

Setting this bit to 1 forces the encoder divider to run open loop.

ENC\_DIV\_FCLK\_ SEL R/W, CON67[31..29], Cyton-CXP, Axion-CL

Reserved for future support for alternate Encoder Divider PLL Master clock frequencies. Currently must be set to 0, which selects 125 MHz clock.

AXN-9-10 BitFlow, Inc. Version A.0

# 9.5 CON68 Register

| Bit | Name               |
|-----|--------------------|
| 0   | RD_ENCQ_SELECTED   |
| 1   | RD_ENCDIV_SELECTED |
| 2   | Reserved           |
| 3   | Reserved           |
| 4   | Reserved           |
| 5   | Reserved           |
| 6   | Reserved           |
| 7   | Reserved           |
| 8   | Reserved           |
| 9   | Reserved           |
| 10  | Reserved           |
| 11  | Reserved           |
| 12  | Reserved           |
| 13  | Reserved           |
| 14  | Reserved           |
| 15  | Reserved           |
| 16  | Reserved           |
| 17  | Reserved           |
| 18  | Reserved           |
| 19  | Reserved           |
| 20  | Reserved           |
| 21  | Reserved           |
| 22  | Reserved           |
| 23  | Reserved           |
| 24  | Reserved           |
| 25  | Reserved           |
| 26  | Reserved           |
| 27  | Reserved           |
| 28  | Reserved           |
| 29  | Reserved           |
| 30  | Reserved           |
| 31  | Reserved           |

CON68 Register The Axion-CL

RD\_ENCQ\_ SELECTED RO, CON68[0], Cyton-CXP, Axion-CL

This bit indicates the current state of selected quad encoder circuit output.

RD\_ENCDIV\_ SELECTED RO, CON68[1], Cyton-CXP, Axion-CL

This bit displays the current state of the selected encoder divider output.

AXN-9-12 BitFlow, Inc. Version A.0

# 9.6 CON69 Register

| Bit | Name           |
|-----|----------------|
| 0   | QENC_COUNT     |
| 1   | QENC_COUNT     |
| 2   | QENC_COUNT     |
| 3   | QENC_COUNT     |
| 4   | QENC_COUNT     |
| 5   | QENC_COUNT     |
| 6   | QENC_COUNT     |
| 7   | QENC_COUNT     |
| 8   | QENC_COUNT     |
| 9   | QENC_COUNT     |
| 10  | QENC_COUNT     |
| 11  | QENC_COUNT     |
| 12  | QENC_COUNT     |
| 13  | QENC_COUNT     |
| 14  | QENC_COUNT     |
| 15  | QENC_COUNT     |
| 16  | QENC_COUNT     |
| 17  | QENC_COUNT     |
| 18  | QENC_COUNT     |
| 19  | QENC_COUNT     |
| 20  | QENC_COUNT     |
| 21  | QENC_COUNT     |
| 22  | QENC_COUNT     |
| 23  | QENC_COUNT     |
| 24  | QENC_PHASEA    |
| 25  | QENC_PHASEB    |
| 26  | QENC_DIR       |
| 27  | QENC_INTRVL_IN |
| 28  | QENC_NEW_LINES |
| 29  | Reserved       |
| 30  | QENC_FREQ      |
| 31  | QENC_FREQ      |

CON69 Register The Axion-CL

**QENC\_COUNT** RO, CON69[23..0], Cyton-CXP, Axion-CL

This bitfield displays the current quadrature encoder count.

**QENC\_PHASEA** RO, CON69[24], Cyton-CXP, Axion-CL

This bit displays the current logic level of the A quadrature encoder phase.

**QENC\_PHASEB** RO, CON69[25], Cyton-CXP, Axion-CL

This bit displays the current logic level of the B quadrature encoder phase.

**QENC\_DIR** RO, CON69[26], Cyton-CXP, Axion-CL

This bit displays the current quadrature encoder direction.

| QENC_DIR | Meaning               |
|----------|-----------------------|
| 0        | Direction is negative |
| 1        | Direction is positive |

# QENC\_INTRVL\_IN

RO, CON69[27], Cyton-CXP, Axion-CL

This bit indicates the current status of the quadrature encoder if the system is in interval mode (see QENC\_INTRVL\_MODE).

| QENC_INTRVL_IN | Meaning                                                                                                                            |
|----------------|------------------------------------------------------------------------------------------------------------------------------------|
| 0              | System is not inside the interval. Encoder counter is not between QENC_INTRVL_LL and QENC_INTRVL_UL. Lines are not being acquired. |
| 1              | System is inside the interval. Encoder counter is between QENC_INTRVL_LL and QENC_INTRVL_UL. Lines are being acquired.             |

AXN-9-14 BitFlow, Inc. Version A.0

### QENC\_NEW\_ LINES

RO, CON69[28], Cyton-CXP, Axion-CL

This bit indicates if the system is at an encoder count that corresponds to a new line. When QENC\_NO\_REAQ = 1, only lines that have not yet been scanned are acquired. This bit can be used to determine of new lines are being traversed, or if the system has backed up, and is revisiting old lines.

| QENC_NEW_LINES | Meaning                                                                                                           |
|----------------|-------------------------------------------------------------------------------------------------------------------|
| 0              | The system is traversing lines that have already been visited. If QENC_NO_REAQ = 1, lines are not being acquired. |
| 1              | The system is traversing new lines. Lines are being acquired.                                                     |

### QENC\_FREQ

RO, CON69[31..30], Cyton-CXP, Axion-CL

Reserved for future support for alternate decoder timing.

CON69 Register The Axion-CL

AXN-9-16 BitFlow, Inc. Version A.0

Axion Camera Link Registers Introduction

# **Axion Camera Link Registers**

# Chapter 10

### 10.1 Introduction

This section contains definitions for registers that are only on the Axion-CL platform. The Cyton-CXP and the Axion-CL have many of the same registers, but some are only relevant to CXP and some are only used for Camera Link. This chapter contains the latter.

CL\_IOBUF\_CTL The Axion-CL

# 10.2 CL\_IOBUF\_CTL

| Bit | Name          |
|-----|---------------|
| 0   | IOBUF_SETTING |
| 1   | IOBUF_SETTING |
| 2   | IOBUF_SETTING |
| 3   | IOBUF_SETTING |
| 4   | IOBUF_SETTING |
| 5   | Reserved      |
| 6   | Reserved      |
| 7   | Reserved      |
| 8   | IOBUF_LANE    |
| 9   | IOBUF_LANE    |
| 10  | IOBUF_LANE    |
| 11  | Reserved      |
| 12  | IOBUF_CHAN    |
| 13  | IOBUF_CHAN    |
| 14  | IOBUF_CHAN    |
| 15  | IOBUF_CHAN    |
| 16  | Reserved      |
| 17  | Reserved      |
| 18  | Reserved      |
| 19  | Reserved      |
| 20  | Reserved      |
| 21  | Reserved      |
| 22  | Reserved      |
| 23  | Reserved      |
| 24  | Reserved      |
| 25  | Reserved      |
| 26  | Reserved      |
| 27  | Reserved      |
| 28  | Reserved      |
| 29  | Reserved      |
| 30  | IOBUF_WRITE   |
| 31  | IOBUF_BUSY    |

AXN-10-2 BitFlow, Inc. Version A.0

Axion Camera Link Registers CL IOBUF CTL

**IOBUF\_SETTING** R/W, CL\_IOBUF\_CTL[4..0], Axion-CL

This Bitfield is used to program the Camera Link receiver settings. It should not be

programmed directly by customers.

**IOBUF\_LANE** R/W, CL\_IOBUF\_CTL[10..8], Axion-CL

This Bitfield is used to program the Camera Link receiver settings. It should not be

programmed directly by customers.

**IOBUF\_CHAN** R/W, CL\_IOBUF\_CTL[15..12], Axion-CL

This Bitfield is used to program the Camera Link receiver settings. It should not be

programmed directly by customers.

**IOBUF\_WRITE** R/W, CL\_IOBUF\_CTL[30], Axion-CL

This Bitfield is used to program the Camera Link receiver settings. It should not be

programmed directly by customers.

**IOBUF\_BUSY** R/W, CL\_IOBUF\_CTL[31], Axion-CL

This Bitfield is used to program the Camera Link receiver settings. It should not be

programmed directly by customers.

CL\_CHAN\_CONFIG The Axion-CL

# 10.3 CL\_CHAN\_CONFIG

| Bit | Name                 |
|-----|----------------------|
| 0   | PLL_PLL_PHASE_DIR    |
| 1   | PLL_ADJUST_PLL_PHASE |
| 2   | PLL_CONFIG_ERROR     |
| 3   | PLL_RST              |
| 4   | ALIGN_MANUAL_RST     |
| 5   | ALIGN_MANUAL_DELAY   |
| 6   | ALIGN_MANUAL_LOCK    |
| 7   | ALIGN_MANUAL_EN      |
| 8   | ALIGN_AUTO_EN        |
| 9   | Reserved             |
| 10  | Reserved             |
| 11  | Reserved             |
| 12  | Reserved             |
| 13  | Reserved             |
| 14  | Reserved             |
| 15  | Reserved             |
| 16  | Reserved             |
| 17  | Reserved             |
| 18  | Reserved             |
| 19  | Reserved             |
| 20  | Reserved             |
| 21  | Reserved             |
| 22  | Reserved             |
| 23  | Reserved             |
| 24  | Reserved             |
| 25  | Reserved             |
| 26  | Reserved             |
| 27  | Reserved             |
| 28  | PLL_CHAN             |
| 29  | PLL_CHAN             |
| 30  | PLL_CHAN             |
| 31  | PLL_CONFIG_BUSY      |

AXN-10-4 BitFlow, Inc. Version A.0

Axion Camera Link Registers CL CHAN CONFIG

PLL\_PLL\_ PHASE\_DIR R/W, CL\_CHAN\_CONFIG[0], Axion-CL

This Bitfield is used to program the Camera Link receiver settings. It should not but programmed directly by customers.

PLL\_ADJUST\_ PLL\_PHASE R/W, CL\_CHAN\_CONFIG[1], Axion-CL

This Bitfield is used to program the Camera Link receiver settings. It should not but programmed directly by customers.

PLL\_CONFIG\_ ERROR

R/W, CL\_CHAN\_CONFIG[2], Axion-CL

This Bitfield is used to program the Camera Link receiver settings. It should not but programmed directly by customers.

**PLL RST** 

R/W, CL CHAN CONFIG[3], Axion-CL

This Bitfield is used to program the Camera Link receiver settings. It should not but programmed directly by customers.

ALIGN\_ MANUAL\_RST R/W, CL\_CHAN\_CONFIG[4], Axion-CL

This Bitfield is used to program the Camera Link receiver settings. It should not but programmed directly by customers.

ALIGN\_ MANUAL\_ DELAY R/W, CL\_CHAN\_CONFIG[5], Axion-CL

This Bitfield is used to program the Camera Link receiver settings. It should not but programmed directly by customers.

ALIGN\_ MANUAL\_LOCK R/W, CL\_CHAN\_CONFIG[6], Axion-CL

This Bitfield is used to program the Camera Link receiver settings. It should not but programmed directly by customers.

ALIGN\_ MANUAL\_EN R/W, CL\_CHAN\_CONFIG[7], Axion-CL

This Bitfield is used to program the Camera Link receiver settings. It should not but programmed directly by customers.

CL CHAN CONFIG The Axion-CL

ALIGN\_AUTO\_ EN R/W, CL\_CHAN\_CONFIG[8], Axion-CL

This Bitfield is used to program the Camera Link receiver settings. It should not but

programmed directly by customers.

**PLL\_CHAN** R/W, CL\_CHAN\_CONFIG[30..28], Axion-CL

This Bitfield is used to program the Camera Link receiver settings. It should not but

programmed directly by customers.

PLL\_CONFIG\_ BUSY R/W, CL\_CHAN\_CONFIG[31], Axion-CL

This Bitfield is used to program the Camera Link receiver settings. It should not but

programmed directly by customers.

AXN-10-6 BitFlow, Inc. Version A.0

Axion Camera Link Registers ADDR\_UART\_CON\_BASE

# 10.4 ADDR\_UART\_CON\_BASE

| Bit | Name                |  |
|-----|---------------------|--|
| 0   | RS232_TX_DATA       |  |
| 1   | RS232_TX_DATA       |  |
| 2   | RS232_TX_DATA       |  |
| 3   | RS232_TX_DATA       |  |
| 4   | RS232_TX_DATA       |  |
| 5   | RS232_TX_DATA       |  |
| 6   | RS232_TX_DATA       |  |
| 7   | RS232_TX_DATA       |  |
| 8   | RS232_TX_GO         |  |
| 9   | RS232_RX_INT_ENABLE |  |
| 10  | RS232_RX_FIFO_CLEAR |  |
| 11  | RS232_RX_INVERT     |  |
| 12  | RS232_TX_INVERT     |  |
| 13  | Reserved            |  |
| 14  | Reserved            |  |
| 15  | Reserved            |  |
| 16  | RS232_BAUD_RATE     |  |
| 17  | RS232_BAUD_RATE     |  |
| 18  | RS232_BAUD_RATE     |  |
| 19  | RS232_BAUD_RATE     |  |
| 20  | RS232_BAUD_RATE     |  |
| 21  | RS232_BAUD_RATE     |  |
| 22  | RS232_BAUD_RATE     |  |
| 23  | RS232_BAUD_RATE     |  |
| 24  | RS232_RX_LEVEL      |  |
| 25  | RS232_RX_LEVEL      |  |
| 26  | RS232_RX_LEVEL      |  |
| 27  | RS232_RX_LEVEL      |  |
| 28  | Reserved            |  |
| 29  | RS232_RX_OVERFLOW   |  |
| 30  | RS232_RX_REQ        |  |
| 31  | RS232_TX_READY      |  |

ADDR UART CON BASE The Axion-CL

RS232\_TX\_ DATA R/W, ADDR\_UART\_CON\_BASE[7..0], Axion-CL

Data byte to be sent out the CL RS-232 link.

RS232 TX GO

R/W, ADDR\_UART\_CON\_BASE[8], Axion-CL

Cause the data byte to be sent out the CL RS-232 link.

RS232\_RX\_INT\_ ENABLE R/W, ADDR\_UART\_CON\_BASE[9], Axion-CL

Enable the interrupt that is asserted whenever a byte is received on the CL RS-232

link.

RS232\_RX\_ FIFO\_CLEAR R/W, ADDR\_UART\_CON\_BASE[10], Axion-CL

Clear the CL RS-232 receive FIFO.

RS232\_RX\_INVERT

R/W, ADDR\_UART\_CON\_BASE[11], Axion-CL

Describe RS232\_RX\_INVERT.

RS232\_TX\_INVERT

R/W, ADDR\_UART\_CON\_BASE[12], Axion-CL

Describe RS232\_TX\_INVERT.

RS232\_BAUD\_ RATE R/W, ADDR\_UART\_CON\_BASE[23..16], Axion-CL

Sets the CL RS-232 baud rate.

RS232\_RX\_ LEVEL R/W, ADDR UART CON BASE[27..24], Axion-CL

Describe RS232\_RX\_LEVEL.

RS232\_RX\_ OVERFLOW R/W, ADDR\_UART\_CON\_BASE[29], Axion-CL

Indicates that the CL RS-232 receive FIFO has overflowed.

RS232\_RX\_REQ R/W, ADDI

R/W, ADDR\_UART\_CON\_BASE[30], Axion-CL

Register is 1 when t are bytes in the CL RS-232 receive FIFO..

Axion Camera Link Registers ADDR\_UART\_CON\_BASE

RS232\_TX\_ READY R/W, ADDR\_UART\_CON\_BASE[31], Axion-CL

When this bitfield is 1 the UART is ready to send another byte.

ADDR\_UART\_RDAT\_BASE

The Axion-CL

# 10.5 ADDR\_UART\_RDAT\_BASE

| Bit | Name          |
|-----|---------------|
| 0   | RS232_RX_DATA |
| 1   | RS232_RX_DATA |
| 2   | RS232_RX_DATA |
| 3   | RS232_RX_DATA |
| 4   | RS232_RX_DATA |
| 5   | RS232_RX_DATA |
| 6   | RS232_RX_DATA |
| 7   | RS232_RX_DATA |
| 8   | Reserved      |
| 9   | Reserved      |
| 10  | Reserved      |
| 11  | Reserved      |
| 12  | Reserved      |
| 13  | Reserved      |
| 14  | Reserved      |
| 15  | Reserved      |
| 16  | Reserved      |
| 17  | Reserved      |
| 18  | Reserved      |
| 19  | Reserved      |
| 20  | Reserved      |
| 21  | Reserved      |
| 22  | Reserved      |
| 23  | Reserved      |
| 24  | Reserved      |
| 25  | Reserved      |
| 26  | Reserved      |
| 27  | Reserved      |
| 28  | Reserved      |
| 29  | Reserved      |
| 30  | Reserved      |
| 31  | Reserved      |

AXN-10-10 BitFlow, Inc. Version A.0

Axion Camera Link Registers ADDR\_UART\_RDAT\_BASE

#### RS232\_RX\_ DATA

RO, ADDR\_UART\_RDAT\_BASE[7..0], Axion-CL

The top of the CL RS-232 receive FIFO. Ready this register removes this byte from the FIFO.

ADDR\_CL\_CON\_BASE The Axion-CL

# 10.6 ADDR\_CL\_CON\_BASE

| Bit | Name        |
|-----|-------------|
| 0   | CL_USE_FVAL |
| 1   | CL_USE_DVAL |
| 2   | Reserved    |
| 3   | Reserved    |
| 4   | CL_CHAN_EN  |
| 5   | CL_CHAN_EN  |
| 6   | CL_CHAN_EN  |
| 7   | Reserved    |
| 8   | CL_LVAL_POS |
| 9   | CL_LVAL_POS |
| 10  | CL_LVAL_POS |
| 11  | Reserved    |
| 12  | CL_MODE     |
| 13  | CL_MODE     |
| 14  | CL_MODE     |
| 15  | Reserved    |
| 16  | Reserved    |
| 17  | Reserved    |
| 18  | Reserved    |
| 19  | Reserved    |
| 20  | Reserved    |
| 21  | Reserved    |
| 22  | Reserved    |
| 23  | Reserved    |
| 24  | Reserved    |
| 25  | Reserved    |
| 26  | Reserved    |
| 27  | Reserved    |
| 28  | Reserved    |
| 29  | Reserved    |
| 30  | Reserved    |
| 31  | Reserved    |

AXN-10-12 BitFlow, Inc. Version A.0

Axion Camera Link Registers ADDR\_CL\_CON\_BASE

**CL\_USE\_FVAL** R/W, ADDR\_CL\_CON\_BASE[0], Axion-CL

Describe CL\_USE\_FVAL .

**CL\_USE\_DVAL** R/W, ADDR\_CL\_CON\_BASE[1], Axion-CL

Describe CL\_USE\_DVAL.

**CL\_CHAN\_EN** R/W, ADDR\_CL\_CON\_BASE[6..4], Axion-CL

Each bit in this bitfield enables the corresponding CL channel. The LSB is the base CL

channel.

**CL\_LVAL\_POS** R/W, ADDR\_CL\_CON\_BASE[10..8], Axion-CL

 ${\sf Describe}\ {\sf CL\_LVAL\_POS}\ .$ 

**CL\_MODE** R/W, ADDR\_CL\_CON\_BASE[14..12], Axion-CL

Controls the CL tap decoder mode.

| CL_MODE  | Meaning                        |
|----------|--------------------------------|
| 0 (000b) | Base/Medium/Full, 8-Bit        |
| 1 (001b) | Base/Medium/Full, 10 to 12-Bit |
| 2 (010b) | Base/Medium/Full, 14 to 16Bit  |
| 3 (011b) | Ten-Tap, 8-bit                 |
| 4 (100b) | Eight-Tap, 10-Bit              |
| 5 (101b) | Reserved                       |
| 6 (110b) | Reserved                       |
| 7 (111b) | Reserved                       |
|          |                                |

ADDR\_TAP\_CON\_BASE The Axion-CL

# 10.7 ADDR\_TAP\_CON\_BASE

| Bit | Name          |
|-----|---------------|
| 0   | TAP_MODE      |
| 1   | Reserved      |
| 2   | Reserved      |
| 3   | Reserved      |
| 4   | TAP_FIXED_VAL |
| 5   | TAP_FIXED_VAL |
| 6   | TAP_FIXED_VAL |
| 7   | TAP_FIXED_VAL |
| 8   | TAP_FIXED_VAL |
| 9   | TAP_FIXED_VAL |
| 10  | TAP_FIXED_VAL |
| 11  | TAP_FIXED_VAL |
| 12  | TAP_FIXED_VAL |
| 13  | TAP_FIXED_VAL |
| 14  | TAP_FIXED_VAL |
| 15  | TAP_FIXED_VAL |
| 16  | TAP_FIXED_VAL |
| 17  | TAP_FIXED_VAL |
| 18  | TAP_FIXED_VAL |
| 19  | TAP_FIXED_VAL |
| 20  | Reserved      |
| 21  | Reserved      |
| 22  | Reserved      |
| 23  | Reserved      |
| 24  | Reserved      |
| 25  | Reserved      |
| 26  | Reserved      |
| 27  | Reserved      |
| 28  | Reserved      |
| 29  | Reserved      |
| 30  | Reserved      |
| 31  | TAP_OUTPUT_16 |

AXN-10-14 BitFlow, Inc. Version A.0

Axion Camera Link Registers ADDR\_TAP\_CON\_BASE

**TAP\_MODE** R/W, ADDR\_TAP\_CON\_BASE[0], Axion-CL

Reserved.

**TAP\_FIXED\_VAL** R/W, ADDR\_TAP\_CON\_BASE[19..4], Axion-CL

Reserved.

**TAP\_OUTPUT\_** R/W, ADDR\_TAP\_CON\_BASE[31], Axion-CL

16

This bit should be set to 1 to output 10 to 16 bit pixels as 16-bit words.

# 10.8 ADDR\_TAP\_TABLE\_ADDR\_BASE

| Bit | Name            |
|-----|-----------------|
| 0   | TAP_TABLE_OFFS  |
| 1   | TAP_TABLE_OFFS  |
| 2   | TAP_TABLE_OFFS  |
| 3   | TAP_TABLE_OFFS  |
| 4   | Reserved        |
| 5   | Reserved        |
| 6   | Reserved        |
| 7   | Reserved        |
| 8   | Reserved        |
| 9   | Reserved        |
| 10  | Reserved        |
| 11  | Reserved        |
| 12  | Reserved        |
| 13  | Reserved        |
| 14  | Reserved        |
| 15  | Reserved        |
| 16  | TAP_TABLE_INDEX |
| 17  | TAP_TABLE_INDEX |
| 18  | TAP_TABLE_INDEX |
| 19  | TAP_TABLE_INDEX |
| 20  | Reserved        |
| 21  | Reserved        |
| 22  | Reserved        |
| 23  | Reserved        |
| 24  | TAP_TABLE_TYPE  |
| 25  | TAP_TABLE_TYPE  |
| 26  | Reserved        |
| 27  | Reserved        |
| 28  | Reserved        |
| 29  | Reserved        |
| 30  | Reserved        |
| 31  | Reserved        |

AXN-10-16 BitFlow, Inc. Version A.0

#### TAP\_TABLE\_ OFFS

R/W, ADDR\_TAP\_TABLE\_ADDR\_BASE[3..0], Axion-CL

This register is used to program that Axion's tap re-formatter. It should not be programmed directly by users.

# TAP\_TABLE\_INDEX

R/W, ADDR\_TAP\_TABLE\_ADDR\_BASE[19..16], Axion-CL

This register is used to program that Axion's tap re-formatter. It should not be programmed directly by users.

#### TAP\_TABLE\_ TYPE

R/W, ADDR\_TAP\_TABLE\_ADDR\_BASE[25..24], Axion-CL

This register is used to program that Axion's tap re-formatter. It should not be programmed directly by users.

ADDR\_TAP\_TABLE\_DAT\_BASE

The Axion-CL

# 10.9 ADDR\_TAP\_TABLE\_DAT\_BASE

| Bit | Name     |
|-----|----------|
| 0   | TAP_DATA |
| 1   | TAP_DATA |
| 2   | TAP_DATA |
| 3   | TAP_DATA |
| 4   | TAP_DATA |
| 5   | TAP_DATA |
| 6   | TAP_DATA |
| 7   | TAP_DATA |
| 8   | TAP_DATA |
| 9   | TAP_DATA |
| 10  | TAP_DATA |
| 11  | TAP_DATA |
| 12  | TAP_DATA |
| 13  | TAP_DATA |
| 14  | TAP_DATA |
| 15  | TAP_DATA |
| 16  | TAP_DATA |
| 17  | TAP_DATA |
| 18  | TAP_DATA |
| 19  | TAP_DATA |
| 20  | TAP_DATA |
| 21  | TAP_DATA |
| 22  | TAP_DATA |
| 23  | TAP_DATA |
| 24  | TAP_DATA |
| 25  | TAP_DATA |
| 26  | TAP_DATA |
| 27  | TAP_DATA |
| 28  | TAP_DATA |
| 29  | TAP_DATA |
| 30  | TAP_DATA |
| 31  | TAP_DATA |

AXN-10-18 BitFlow, Inc. Version A.0

### **TAP\_DATA** R/W, ADDR\_TAP\_TABLE\_DAT\_BASE[31..0], Axion-CL

This register is used to program that Axion's tap re-formatter. It should not be programmed directly by users.

ADDR\_FLASH\_CON\_BASE The Axion-CL

# 10.10 ADDR\_FLASH\_CON\_BASE

| Bit | Name                 |
|-----|----------------------|
| 0   | FLASH_CODE           |
| 1   | FLASH_CODE           |
| 2   | FLASH_CODE           |
| 3   | FLASH_CODE           |
| 4   | FLASH_CODE           |
| 5   | FLASH_CODE           |
| 6   | FLASH_CODE           |
| 7   | FLASH_CODE           |
| 8   | FLASH_WRITE          |
| 9   | FLASH_SHIFTBYTE      |
| 10  | FLASH_READ           |
| 11  | FLASH_RESET          |
| 12  | FLASH_BULK_ERASE     |
| 13  | FLASH_SECTOR_ERASE   |
| 14  | FLASH_SECTOR_PROTECT |
| 15  | FLASH_EN4B_ADDR      |
| 16  | FLASH_EX4B_ADDR      |
| 17  | FLASH_READ_RDID      |
| 18  | FLASH_READ_STATUS    |
| 19  | Reserved             |
| 20  | Reserved             |
| 21  | Reserved             |
| 22  | Reserved             |
| 23  | Reserved             |
| 24  | Reserved             |
| 25  | Reserved             |
| 26  | Reserved             |
| 27  | Reserved             |
| 28  | FLASH_ILLEGAL_WRITE  |
| 29  | FLASH_ILLEGAL_ERASE  |
| 30  | FLASH_DATA_VALID     |
| 31  | FLASH_BUSY           |

AXN-10-20 BitFlow, Inc. Version A.0

Axion Camera Link Registers ADDR FLASH CON BASE

FLASH CODE R/W, ADDR FLASH CON BASE[7..0], Axion-CL

This bitfield is used to program the boards flash memory. It should not be pro-

grammed directly by customers.

**FLASH WRITE** R/W, ADDR\_FLASH\_CON\_BASE[8], Axion-CL

This bitfield is used to program the boards flash memory. It should not be pro-

grammed directly by customers.

FLASH **SHIFTBYTE**  R/W, ADDR\_FLASH\_CON\_BASE[9], Axion-CL

This bitfield is used to program the boards flash memory. It should not be pro-

grammed directly by customers.

**FLASH READ** R/W, ADDR FLASH CON BASE[10], Axion-CL

This bitfield is used to program the boards flash memory. It should not be pro-

grammed directly by customers.

**FLASH RESET** R/W, ADDR\_FLASH\_CON\_BASE[11], Axion-CL

This bitfield is used to program the boards flash memory. It should not be pro-

grammed directly by customers.

FLASH\_BULK\_ **ERASE** 

R/W, ADDR\_FLASH\_CON\_BASE[12], Axion-CL

This bitfield is used to program the boards flash memory. It should not be pro-

grammed directly by customers.

**ERASE** 

**FLASH\_SECTOR**\_ R/W, ADDR\_FLASH\_CON\_BASE[13], Axion-CL

This bitfield is used to program the boards flash memory. It should not be pro-

grammed directly by customers.

**PROTECT** 

FLASH SECTOR R/W, ADDR FLASH CON BASE[14], Axion-CL

This bitfield is used to program the boards flash memory. It should not be pro-

grammed directly by customers.

ADDR FLASH CON BASE The Axion-CL

#### FLASH EN4B **ADDR**

R/W, ADDR\_FLASH\_CON\_BASE[15], Axion-CL

This bitfield is used to program the boards flash memory. It should not be programmed directly by customers.

#### FLASH EX4B **ADDR**

R/W, ADDR\_FLASH\_CON\_BASE[16], Axion-CL

This bitfield is used to program the boards flash memory. It should not be programmed directly by customers.

#### FLASH\_READ\_ **RDID**

R/W, ADDR\_FLASH\_CON\_BASE[17], Axion-CL

This bitfield is used to program the boards flash memory. It should not be programmed directly by customers.

#### FLASH READ **STATUS**

R/W, ADDR FLASH CON BASE[18], Axion-CL

This bitfield is used to program the boards flash memory. It should not be programmed directly by customers.

# WRITE

FLASH\_ILLEGAL\_ RO, ADDR\_FLASH\_CON\_BASE[28], Axion-CL

This bitfield is used to program the boards flash memory. It should not be programmed directly by customers.

# **ERASE**

FLASH\_ILLEGAL\_ RO, ADDR\_FLASH\_CON\_BASE[29], Axion-CL

This bitfield is used to program the boards flash memory. It should not be programmed directly by customers.

#### FLASH DATA **VALID**

RO, ADDR\_FLASH\_CON\_BASE[30], Axion-CL

This bitfield is used to program the boards flash memory. It should not be programmed directly by customers.

#### **FLASH BUSY**

RO, ADDR FLASH CON BASE[31], Axion-CL

This bitfield is used to program the boards flash memory. It should not be programmed directly by customers.

BitFlow, Inc. AXN-10-22 Version A.0 Axion Camera Link Registers ADDR\_FLASH\_ADDR\_BASE

# 10.11 ADDR\_FLASH\_ADDR\_BASE

| Bit | Name       |
|-----|------------|
| 0   | FLASH_ADDR |
| 1   | FLASH_ADDR |
| 2   | FLASH_ADDR |
| 3   | FLASH_ADDR |
| 4   | FLASH_ADDR |
| 5   | FLASH_ADDR |
| 6   | FLASH_ADDR |
| 7   | FLASH_ADDR |
| 8   | FLASH_ADDR |
| 9   | FLASH_ADDR |
| 10  | FLASH_ADDR |
| 11  | FLASH_ADDR |
| 12  | FLASH_ADDR |
| 13  | FLASH_ADDR |
| 14  | FLASH_ADDR |
| 15  | FLASH_ADDR |
| 16  | FLASH_ADDR |
| 17  | FLASH_ADDR |
| 18  | FLASH_ADDR |
| 19  | FLASH_ADDR |
| 20  | FLASH_ADDR |
| 21  | FLASH_ADDR |
| 22  | FLASH_ADDR |
| 23  | FLASH_ADDR |
| 24  | FLASH_ADDR |
| 25  | FLASH_ADDR |
| 26  | FLASH_ADDR |
| 27  | FLASH_ADDR |
| 28  | FLASH_ADDR |
| 29  | FLASH_ADDR |
| 30  | FLASH_ADDR |
| 31  | FLASH_ADDR |

ADDR\_FLASH\_ADDR\_BASE The Axion-CL

### **FLASH\_ADDR** R/W, ADDR\_FLASH\_ADDR\_BASE[31..0], Axion-CL

This bitfield is used to program the boards flash memory. It should not be programmed directly by customers.

AXN-10-24 BitFlow, Inc. Version A.0

Axion Camera Link Registers ADDR\_FLASH\_DAT\_BASE

# 10.12 ADDR\_FLASH\_DAT\_BASE

| Bit | Name           |
|-----|----------------|
| 0   | FLASH_DATA_OUT |
| 1   | FLASH_DATA_OUT |
| 2   | FLASH_DATA_OUT |
| 3   | FLASH_DATA_OUT |
| 4   | FLASH_DATA_OUT |
| 5   | FLASH_DATA_OUT |
| 6   | FLASH_DATA_OUT |
| 7   | FLASH_DATA_OUT |
| 8   | FLASH_DATA_IN  |
| 9   | FLASH_DATA_IN  |
| 10  | FLASH_DATA_IN  |
| 11  | FLASH_DATA_IN  |
| 12  | FLASH_DATA_IN  |
| 13  | FLASH_DATA_IN  |
| 14  | FLASH_DATA_IN  |
| 15  | FLASH_DATA_IN  |
| 16  | Reserved       |
| 17  | Reserved       |
| 18  | Reserved       |
| 19  | Reserved       |
| 20  | Reserved       |
| 21  | Reserved       |
| 22  | Reserved       |
| 23  | Reserved       |
| 24  | Reserved       |
| 25  | Reserved       |
| 26  | Reserved       |
| 27  | Reserved       |
| 28  | Reserved       |
| 29  | Reserved       |
| 30  | Reserved       |
| 31  | Reserved       |

The Axion-CL ADDR\_FLASH\_DAT\_BASE

#### FLASH\_DATA\_ OUT

R/W, ADDR\_FLASH\_DAT\_BASE[7..0], Axion-CL

This bitfield is used to program the boards flash memory. It should not be programmed directly by customers.

FLASH\_DATA\_IN R/W, ADDR\_FLASH\_DAT\_BASE[15..8], Axion-CL

This bitfield is used to program the boards flash memory. It should not be programmed directly by customers.

AXN-10-26 BitFlow, Inc. Version A.0

# Axion Power and Miscellaneous Registers

# Chapter 11

### 11.1 Introduction

This chapter contains details on the Axion PoCL registers as well as some other miscellaneous registers.

CON104 The Axion-CL

### 11.2 CON104

| Bit | Name                    |  |
|-----|-------------------------|--|
| 0   | 0_POCL_EN_POWER         |  |
| 1   | Reserved                |  |
| 2   | 0_POCL_EN_CAM_SENSE     |  |
| 3   | 0_POCL_HW_DIS           |  |
| 4   | Reserved                |  |
| 5   | 0_POCL_OPEN_DETECTED    |  |
| 6   | 0_POCL_OVER_DETECTED    |  |
| 7   | 0_POCL_OVER_LATCH       |  |
| 8   | Reserved                |  |
| 9   | 0_CL_CLOCK_LOST_LATCH   |  |
| 10  | 0_CL_CLOCK_DETECTED     |  |
| 11  | 0_POCL_STATE            |  |
| 12  | 0_POCL_STATE            |  |
| 13  | 0_POCL_OVR_AUTO_RESTART |  |
| 14  | 0_POCL_SENSE_BYPASS     |  |
| 15  | 0_ENABLE_POCL_SYSTEM    |  |
| 16  | Reserved                |  |
| 17  | Reserved                |  |
| 18  | Reserved                |  |
| 19  | Reserved                |  |
| 20  | Reserved                |  |
| 21  | Reserved                |  |
| 22  | Reserved                |  |
| 23  | Reserved                |  |
| 24  | Reserved                |  |
| 25  | Reserved                |  |
| 26  | Reserved                |  |
| 27  | Reserved                |  |
| 28  | Reserved                |  |
| 29  | Reserved                |  |
| 30  | Reserved                |  |
| 31  | Reserved                |  |

AXN-11-2 BitFlow, Inc. Version A.0

| 0_PC | DCL_ | _EN_ |
|------|------|------|
| POW  | /ER  |      |

RO, CON104[0], Axion-CL

PoCL power has been applied to the camera.

**0\_POCL\_EN\_ CAM\_SENSE** 

RO, CON104[2], Axion-CL

PoCL sense is enabled.

0\_POCL\_HW\_ DIS RO, CON104[3], Axion-CL

Describe 0\_POCL\_HW\_DIS.

0\_POCL\_OPEN\_ DETECTED RO, CON104[5], Axion-CL

Open circuit detected.

0\_POCL\_OVER\_ DETECTED RO, CON104[6], Axion-CL

Over current detected.

0\_POCL\_OVER\_ LATCH RO, CON104[7], Axion-CL

Latched to 1 if over current has been detected.

0\_CL\_CLOCK\_ LOST\_LATCH RO, CON104[9], Axion-CL

Latched to one if CL clock is lost.

0\_CL\_CLOCK\_ DETECTED RO, CON104[10], Axion-CL

Reads back 1 if CL clock is detected.

**0\_POCL\_STATE** RO, CC

RO, CON104[12..11], Axion-CL

Current state of the PoCL state machine.

0\_POCL\_OVR\_ AUTO\_RESTART R/W, CON104[13], Axion-CL

Automatically restart if over current detected.

CON104 The Axion-CL

**BYPASS** 

**0\_POCL\_SENSE\_** R/W, CON104[14], Axion-CL

Bypass the PoCL sense circuit and apply power. This register is for testing only, it

should not be set by the user.

**O\_ENABLE\_** POCL\_SYSTEM R/W, CON104[15], Axion-CL

Poking this bit to 1 enables the PoCL circuit for this connector.

AXN-11-4 BitFlow, Inc. Version A.0

### 11.3 CON105

| Bit | Name                |
|-----|---------------------|
| 0   | 0_POCL_TIMER_OFF    |
| 1   | 0_POCL_TIMER_OFF    |
| 2   | 0_POCL_TIMER_OFF    |
| 3   | 0_POCL_TIMER_OFF    |
| 4   | 0_POCL_TIMER_OFF    |
| 5   | 0_POCL_TIMER_OFF    |
| 6   | 0_POCL_TIMER_OFF    |
| 7   | 0_POCL_TIMER_OFF    |
| 8   | 0_POCL_TIMER_OFF    |
| 9   | 0_POCL_TIMER_OFF    |
| 10  | 0_POCL_TIMER_OFF    |
| 11  | Reserved            |
| 12  | Reserved            |
| 13  | Reserved            |
| 14  | Reserved            |
| 15  | Reserved            |
| 16  | 0_POCL_TIMER_STABLE |
| 17  | 0_POCL_TIMER_STABLE |
| 18  | 0_POCL_TIMER_STABLE |
| 19  | 0_POCL_TIMER_STABLE |
| 20  | 0_POCL_TIMER_STABLE |
| 21  | 0_POCL_TIMER_STABLE |
| 22  | 0_POCL_TIMER_STABLE |
| 23  | 0_POCL_TIMER_STABLE |
| 24  | 0_POCL_TIMER_STABLE |
| 25  | 0_POCL_TIMER_STABLE |
| 26  | 0_POCL_TIMER_STABLE |
| 27  | Reserved            |
| 28  | Reserved            |
| 29  | Reserved            |
| 30  | Reserved            |
| 31  | Reserved            |

CON105 The Axion-CL

OFF

**O\_POCL\_TIMER\_** R/W, CON105[10..0], Axion-CL

This bitfield controls the timing of the PoCL state machine. It should not be changed by the user unless instructed by BitFlow Customer Support.

**STABLE** 

**0\_POCL\_TIMER\_** R/W, CON105[26..16], Axion-CL

This bitfield controls the timing of the PoCL state machine. It should not be changed by the user unless instructed by BitFlow Customer Support.

### 11.4 CON106

| Bit | Name                    |
|-----|-------------------------|
| 0   | 0_POCL_TIMER_ON         |
| 1   | 0_POCL_TIMER_ON         |
| 2   | 0_POCL_TIMER_ON         |
| 3   | 0_POCL_TIMER_ON         |
| 4   | 0_POCL_TIMER_ON         |
| 5   | 0_POCL_TIMER_ON         |
| 6   | 0_POCL_TIMER_ON         |
| 7   | 0_POCL_TIMER_ON         |
| 8   | 0_POCL_TIMER_ON         |
| 9   | 0_POCL_TIMER_ON         |
| 10  | 0_POCL_TIMER_ON         |
| 11  | Reserved                |
| 12  | Reserved                |
| 13  | Reserved                |
| 14  | Reserved                |
| 15  | Reserved                |
| 16  | 0_POCL_TIMER_DISCONNECT |
| 17  | 0_POCL_TIMER_DISCONNECT |
| 18  | 0_POCL_TIMER_DISCONNECT |
| 19  | 0_POCL_TIMER_DISCONNECT |
| 20  | 0_POCL_TIMER_DISCONNECT |
| 21  | 0_POCL_TIMER_DISCONNECT |
| 22  | 0_POCL_TIMER_DISCONNECT |
| 23  | 0_POCL_TIMER_DISCONNECT |
| 24  | 0_POCL_TIMER_DISCONNECT |
| 25  | 0_POCL_TIMER_DISCONNECT |
| 26  | 0_POCL_TIMER_DISCONNECT |
| 27  | Reserved                |
| 28  | Reserved                |
| 29  | Reserved                |
| 30  | Reserved                |
| 31  | Reserved                |

CON106 The Axion-CL

ON

**O\_POCL\_TIMER\_** R/W, CON106[10..0], Axion-CL

This bitfield controls the timing of the PoCL state machine. It should not be changed by the user unless instructed by BitFlow Customer Support.

0\_POCL\_TIMER\_ **DISCONNECT** 

R/W, CON106[26..16], Axion-CL

This bitfield controls the timing of the PoCL state machine. It should not be changed by the user unless instructed by BitFlow Customer Support.

### 11.5 CON136

| Bit | Name                    |
|-----|-------------------------|
| 0   | 1_POCL_EN_POWER         |
| 1   | Reserved                |
| 2   | 1_POCL_EN_CAM_SENSE     |
| 3   | 1_POCL_HW_DIS           |
| 4   | Reserved                |
| 5   | 1_POCL_OPEN_DETECTED    |
| 6   | 1_POCL_OVER_DETECTED    |
| 7   | 1_POCL_OVER_LATCH       |
| 8   | Reserved                |
| 9   | 1_CL_CLOCK_LOST_LATCH   |
| 10  | 1_CL_CLOCK_DETECTED     |
| 11  | 1_POCL_STATE            |
| 12  | 1_POCL_STATE            |
| 13  | 1_POCL_OVR_AUTO_RESTART |
| 14  | 1_POCL_SENSE_BYPASS     |
| 15  | 1_ENABLE_POCL_SYSTEM    |
| 16  | Reserved                |
| 17  | Reserved                |
| 18  | Reserved                |
| 19  | Reserved                |
| 20  | Reserved                |
| 21  | Reserved                |
| 22  | Reserved                |
| 23  | Reserved                |
| 24  | Reserved                |
| 25  | Reserved                |
| 26  | Reserved                |
| 27  | Reserved                |
| 28  | Reserved                |
| 29  | Reserved                |
| 30  | Reserved                |
| 31  | Reserved                |

CON136 The Axion-CL

1\_POCL\_EN\_ POWER RO, CON136[0], Axion-CL

See 0\_POCL\_EN\_POWER.

1\_POCL\_EN\_ CAM\_SENSE RO, CON136[2], Axion-CL

See 0\_POCL\_EN\_CAM\_SENSE.

1\_POCL\_HW\_ DIS RO, CON136[3], Axion-CL

See 0\_POCL\_HW\_DIS.

1\_POCL\_OPEN\_ DETECTED RO, CON136[5], Axion-CL

See 0\_POCL\_OPEN\_DETECTED.

1\_POCL\_OVER\_ DETECTED RO, CON136[6], Axion-CL

See 0\_POCL\_OVER\_DETECTED.

1\_POCL\_OVER\_ LATCH RO, CON136[7], Axion-CL

See 0\_POCL\_OVER\_LATCH.

1\_CL\_CLOCK\_ LOST\_LATCH RO, CON136[9], Axion-CL

See 0\_CL\_CLOCK\_LOST\_LATCH.

1\_CL\_CLOCK\_ DETECTED

RO, CON136[10], Axion-CL

See 0\_CL\_CLOCK\_DETECTED.

**1\_POCL\_STATE** RO, CON136[12..11], Axion-CL

See 0\_POCL\_STATE.

1\_POCL\_OVR\_ AUTO\_RESTART R/W, CON136[13], Axion-CL

See 0\_POCL\_OVR\_AUTO\_RESTART.

**1\_POCL\_SENSE**\_ R/W, CON136[14], Axion-CL **BYPASS** 

See 0\_POCL\_SENSE\_BYPASS.

**1\_ENABLE\_** R/W, CON136[15], Axion-CL **POCL\_SYSTEM** 

See 0\_ENABLE\_POCL\_SYSTEM.

CON137 The Axion-CL

### 11.6 CON137

| Bit | Name                |
|-----|---------------------|
| 0   | 1_POCL_TIMER_OFF    |
| 1   | 1_POCL_TIMER_OFF    |
| 2   | 1_POCL_TIMER_OFF    |
| 3   | 1_POCL_TIMER_OFF    |
| 4   | 1_POCL_TIMER_OFF    |
| 5   | 1_POCL_TIMER_OFF    |
| 6   | 1_POCL_TIMER_OFF    |
| 7   | 1_POCL_TIMER_OFF    |
| 8   | 1_POCL_TIMER_OFF    |
| 9   | 1_POCL_TIMER_OFF    |
| 10  | 1_POCL_TIMER_OFF    |
| 11  | Reserved            |
| 12  | Reserved            |
| 13  | Reserved            |
| 14  | Reserved            |
| 15  | Reserved            |
| 16  | 1_POCL_TIMER_STABLE |
| 17  | 1_POCL_TIMER_STABLE |
| 18  | 1_POCL_TIMER_STABLE |
| 19  | 1_POCL_TIMER_STABLE |
| 20  | 1_POCL_TIMER_STABLE |
| 21  | 1_POCL_TIMER_STABLE |
| 22  | 1_POCL_TIMER_STABLE |
| 23  | 1_POCL_TIMER_STABLE |
| 24  | 1_POCL_TIMER_STABLE |
| 25  | 1_POCL_TIMER_STABLE |
| 26  | 1_POCL_TIMER_STABLE |
| 27  | Reserved            |
| 28  | Reserved            |
| 29  | Reserved            |
| 30  | Reserved            |
| 31  | Reserved            |

AXN-11-12 BitFlow, Inc. Version A.0

**1\_POCL\_TIMER**\_ R/W, CON137[10..0], Axion-CL **OFF** 

See 0\_POCL\_TIMER\_OFF.

**1\_POCL\_TIMER**\_ R/W, CON137[26..16], Axion-CL **STABLE** 

See 0\_POCL\_TIMER\_STABLE.

CON138 The Axion-CL

### 11.7 CON138

| Bit | Name                    |
|-----|-------------------------|
| 0   | 1_POCL_TIMER_ON         |
| 1   | 1_POCL_TIMER_ON         |
| 2   | 1_POCL_TIMER_ON         |
| 3   | 1_POCL_TIMER_ON         |
| 4   | 1_POCL_TIMER_ON         |
| 5   | 1_POCL_TIMER_ON         |
| 6   | 1_POCL_TIMER_ON         |
| 7   | 1_POCL_TIMER_ON         |
| 8   | 1_POCL_TIMER_ON         |
| 9   | 1_POCL_TIMER_ON         |
| 10  | 1_POCL_TIMER_ON         |
| 11  | Reserved                |
| 12  | Reserved                |
| 13  | Reserved                |
| 14  | Reserved                |
| 15  | Reserved                |
| 16  | 1_POCL_TIMER_DISCONNECT |
| 17  | 1_POCL_TIMER_DISCONNECT |
| 18  | 1_POCL_TIMER_DISCONNECT |
| 19  | 1_POCL_TIMER_DISCONNECT |
| 20  | 1_POCL_TIMER_DISCONNECT |
| 21  | 1_POCL_TIMER_DISCONNECT |
| 22  | 1_POCL_TIMER_DISCONNECT |
| 23  | 1_POCL_TIMER_DISCONNECT |
| 24  | 1_POCL_TIMER_DISCONNECT |
| 25  | 1_POCL_TIMER_DISCONNECT |
| 26  | 1_POCL_TIMER_DISCONNECT |
| 27  | Reserved                |
| 28  | Reserved                |
| 29  | Reserved                |
| 30  | Reserved                |
| 31  | Reserved                |

AXN-11-14 BitFlow, Inc. Version A.0

**1\_POCL\_TIMER**\_ R/W, CON138[10..0], Axion-CL **ON** 

See 0\_POCL\_TIMER\_ON.

1\_POCL\_TIMER\_ DISCONNECT

R/W, CON138[26..16], Axion-CL

See 0\_POCL\_TIMER\_DISCONNECT.

CON168 The Axion-CL

# 11.8 CON168

| Bit | Name                    |
|-----|-------------------------|
| 0   | 2_POCL_EN_POWER         |
| 1   | Reserved                |
| 2   | 2_POCL_EN_CAM_SENSE     |
| 3   | 2_POCL_HW_DIS           |
| 4   | Reserved                |
| 5   | 2_POCL_OPEN_DETECTED    |
| 6   | 2_POCL_OVER_DETECTED    |
| 7   | 2_POCL_OVER_LATCH       |
| 8   | Reserved                |
| 9   | 2_CL_CLOCK_LOST_LATCH   |
| 10  | 2_CL_CLOCK_DETECTED     |
| 11  | 2_POCL_STATE            |
| 12  | 2_POCL_STATE            |
| 13  | 2_POCL_OVR_AUTO_RESTART |
| 14  | 2_POCL_SENSE_BYPASS     |
| 15  | 2_ENABLE_POCL_SYSTEM    |
| 16  | Reserved                |
| 17  | Reserved                |
| 18  | Reserved                |
| 19  | Reserved                |
| 20  | Reserved                |
| 21  | Reserved                |
| 22  | Reserved                |
| 23  | Reserved                |
| 24  | Reserved                |
| 25  | Reserved                |
| 26  | Reserved                |
| 27  | Reserved                |
| 28  | Reserved                |
| 29  | Reserved                |
| 30  | Reserved                |
| 31  | Reserved                |

AXN-11-16 BitFlow, Inc. Version A.0

| 2_POCL_EN_<br>POWER       | RO, CON168[0], Axion-CL See 0_POCL_EN_POWER.       |
|---------------------------|----------------------------------------------------|
| 2_POCL_EN_<br>CAM_SENSE   | RO, CON168[2], Axion-CL See 0_POCL_EN_CAM_SENSE.   |
| 2_POCL_HW_<br>DIS         | RO, CON168[3], Axion-CL<br>See 0_POCL_HW_DIS.      |
| 2_POCL_OPEN_<br>DETECTED  | RO, CON168[5], Axion-CL See 0_POCL_OPEN_DETECTED.  |
| 2_POCL_OVER_<br>DETECTED  | RO, CON168[6], Axion-CL See 0_POCL_OVER_DETECTED.  |
| 2_POCL_OVER_<br>LATCH     | RO, CON168[7], Axion-CL<br>See 0_POCL_OVER_LATCH.  |
| 2_CL_CLOCK_<br>LOST_LATCH | RO, CON168[9], Axion-CL See 0_CL_CLOCK_LOST_LATCH. |
| 2_CL_CLOCK_<br>DETECTED   | RO, CON168[10], Axion-CL See 0_CL_CLOCK_DETECTED.  |
| 2_POCL_STATE              | RO, CON168[1211], Axion-CL<br>See 0_POCL_STATE.    |

**2\_POCL\_OVR\_ AUTO\_RESTART**R/W, CON168[13], Axion-CL

See 0\_POCL\_OVR\_AUTO\_RESTART.

CON168 The Axion-CL

**2\_POCL\_SENSE\_** R/W, CON168[14], Axion-CL

**BYPASS** 

See 0\_POCL\_SENSE\_BYPASS.

**2\_ENABLE**\_ R/W, CON168[15], Axion-CL **POCL\_SYSTEM** 

See 0\_ENABLE\_POCL\_SYSTEM.

AXN-11-18 BitFlow, Inc. Version A.0

# 11.9 CON169

| Bit | Name                |
|-----|---------------------|
| 0   | 2_POCL_TIMER_OFF    |
| 1   | 2_POCL_TIMER_OFF    |
| 2   | 2_POCL_TIMER_OFF    |
| 3   | 2_POCL_TIMER_OFF    |
| 4   | 2_POCL_TIMER_OFF    |
| 5   | 2_POCL_TIMER_OFF    |
| 6   | 2_POCL_TIMER_OFF    |
| 7   | 2_POCL_TIMER_OFF    |
| 8   | 2_POCL_TIMER_OFF    |
| 9   | 2_POCL_TIMER_OFF    |
| 10  | 2_POCL_TIMER_OFF    |
| 11  | Reserved            |
| 12  | Reserved            |
| 13  | Reserved            |
| 14  | Reserved            |
| 15  | Reserved            |
| 16  | 2_POCL_TIMER_STABLE |
| 17  | 2_POCL_TIMER_STABLE |
| 18  | 2_POCL_TIMER_STABLE |
| 19  | 2_POCL_TIMER_STABLE |
| 20  | 2_POCL_TIMER_STABLE |
| 21  | 2_POCL_TIMER_STABLE |
| 22  | 2_POCL_TIMER_STABLE |
| 23  | 2_POCL_TIMER_STABLE |
| 24  | 2_POCL_TIMER_STABLE |
| 25  | 2_POCL_TIMER_STABLE |
| 26  | 2_POCL_TIMER_STABLE |
| 27  | Reserved            |
| 28  | Reserved            |
| 29  | Reserved            |
| 30  | Reserved            |
| 31  | Reserved            |

CON169 The Axion-CL

**2\_POCL\_TIMER**\_ R/W, CON169[10..0], Axion-CL

OFF

See 0\_POCL\_TIMER\_OFF.

**2\_POCL\_TIMER**\_ R/W, CON169[26..16], Axion-CL **STABLE** 

See 0\_POCL\_TIMER\_STABLE.

AXN-11-20 BitFlow, Inc. Version A.0

# 11.10 CON170

| Bit | Name                    |  |  |  |
|-----|-------------------------|--|--|--|
| 0   | 2_POCL_TIMER_ON         |  |  |  |
| 1   | 2_POCL_TIMER_ON         |  |  |  |
| 2   | 2_POCL_TIMER_ON         |  |  |  |
| 3   | 2_POCL_TIMER_ON         |  |  |  |
| 4   | 2_POCL_TIMER_ON         |  |  |  |
| 5   | 2_POCL_TIMER_ON         |  |  |  |
| 6   | 2_POCL_TIMER_ON         |  |  |  |
| 7   | 2_POCL_TIMER_ON         |  |  |  |
| 8   | 2_POCL_TIMER_ON         |  |  |  |
| 9   | 2_POCL_TIMER_ON         |  |  |  |
| 10  | 2_POCL_TIMER_ON         |  |  |  |
| 11  | Reserved                |  |  |  |
| 12  | Reserved                |  |  |  |
| 13  | Reserved                |  |  |  |
| 14  | Reserved                |  |  |  |
| 15  | Reserved                |  |  |  |
| 16  | 2_POCL_TIMER_DISCONNECT |  |  |  |
| 17  | 2_POCL_TIMER_DISCONNECT |  |  |  |
| 18  | 2_POCL_TIMER_DISCONNECT |  |  |  |
| 19  | 2_POCL_TIMER_DISCONNECT |  |  |  |
| 20  | 2_POCL_TIMER_DISCONNECT |  |  |  |
| 21  | 2_POCL_TIMER_DISCONNECT |  |  |  |
| 22  | 2_POCL_TIMER_DISCONNECT |  |  |  |
| 23  | 2_POCL_TIMER_DISCONNECT |  |  |  |
| 24  | 2_POCL_TIMER_DISCONNECT |  |  |  |
| 25  | 2_POCL_TIMER_DISCONNECT |  |  |  |
| 26  | 2_POCL_TIMER_DISCONNECT |  |  |  |
| 27  | Reserved                |  |  |  |
| 28  | Reserved                |  |  |  |
| 29  | Reserved                |  |  |  |
| 30  | Reserved                |  |  |  |
| 31  | Reserved                |  |  |  |

CON170 The Axion-CL

**2\_POCL\_TIMER**\_ R/W, CON170[10..0], Axion-CL

ON

See 0\_POCL\_TIMER\_ON.

**2\_POCL\_TIMER**\_ R/W, CON170[26..16], Axion-CL **DISCONNECT** 

See 0\_POCL\_TIMER\_DISCONNECT.

AXN-11-22 BitFlow, Inc. Version A.0

# 11.11 CON200

| Bit | Name                    |
|-----|-------------------------|
| 0   | 3_POCL_EN_POWER         |
| 1   | Reserved                |
| 2   | 3_POCL_EN_CAM_SENSE     |
| 3   | 3_POCL_HW_DIS           |
| 4   | Reserved                |
| 5   | 3_POCL_OPEN_DETECTED    |
| 6   | 3_POCL_OVER_DETECTED    |
| 7   | 3_POCL_OVER_LATCH       |
| 8   | Reserved                |
| 9   | 3_CL_CLOCK_LOST_LATCH   |
| 10  | 3_CL_CLOCK_DETECTED     |
| 11  | 3_POCL_STATE            |
| 12  | 3_POCL_STATE            |
| 13  | 3_POCL_OVR_AUTO_RESTART |
| 14  | 3_POCL_SENSE_BYPASS     |
| 15  | 3_ENABLE_POCL_SYSTEM    |
| 16  | Reserved                |
| 17  | Reserved                |
| 18  | Reserved                |
| 19  | Reserved                |
| 20  | Reserved                |
| 21  | Reserved                |
| 22  | Reserved                |
| 23  | Reserved                |
| 24  | Reserved                |
| 25  | Reserved                |
| 26  | Reserved                |
| 27  | Reserved                |
| 28  | Reserved                |
| 29  | Reserved                |
| 30  | Reserved                |
| 31  | Reserved                |

CON200 The Axion-CL

3\_POCL\_EN\_ RO, CON200[0], Axion-CL **POWER** See 0\_POCL\_EN\_POWER. 3 POCL EN RO, CON200[2], Axion-CL CAM\_SENSE See 0\_POCL\_EN\_CAM\_SENSE. 3\_POCL\_HW\_ RO, CON200[3], Axion-CL DIS See 0\_POCL\_HW\_DIS. 3\_POCL\_OPEN\_ RO, CON200[5], Axion-CL **DETECTED** See 0\_POCL\_OPEN\_DETECTED. 3 POCL OVER RO, CON200[6], Axion-CL **DETECTED** See 0\_POCL\_OVER\_DETECTED. 3\_POCL\_OVER\_ RO, CON200[7], Axion-CL LATCH See 0\_POCL\_OVER\_LATCH. 3\_CL\_CLOCK\_ RO, CON200[9], Axion-CL LOST\_LATCH See 0\_CL\_CLOCK\_LOST\_LATCH. 3\_CL\_CLOCK\_ RO, CON200[10], Axion-CL **DETECTED** See 0\_CL\_CLOCK\_DETECTED. 3\_POCL\_STATE RO, CON200[12..11], Axion-CL See 0\_POCL\_STATE. 3 POCL OVR R/W, CON200[13], Axion-CL

**AUTO RESTART** 

AXN-11-24 BitFlow, Inc. Version A.0

See 0\_POCL\_OVR\_AUTO\_RESTART.

**3\_POCL\_SENSE**\_ R/W, CON200[14], Axion-CL **BYPASS** 

See 0\_POCL\_SENSE\_BYPASS.

3\_ENABLE\_ POCL\_SYSTEM R/W, CON200[15], Axion-CL

See 0\_ENABLE\_POCL\_SYSTEM.

CON201 The Axion-CL

# 11.12 CON201

| Bit | Name                |  |  |  |
|-----|---------------------|--|--|--|
| 0   | 3_POCL_TIMER_OFF    |  |  |  |
| 1   | 3_POCL_TIMER_OFF    |  |  |  |
| 2   | 3_POCL_TIMER_OFF    |  |  |  |
| 3   | 3_POCL_TIMER_OFF    |  |  |  |
| 4   | 3_POCL_TIMER_OFF    |  |  |  |
| 5   | 3_POCL_TIMER_OFF    |  |  |  |
| 6   | 3_POCL_TIMER_OFF    |  |  |  |
| 7   | 3_POCL_TIMER_OFF    |  |  |  |
| 8   | 3_POCL_TIMER_OFF    |  |  |  |
| 9   | 3_POCL_TIMER_OFF    |  |  |  |
| 10  | 3_POCL_TIMER_OFF    |  |  |  |
| 11  | Reserved            |  |  |  |
| 12  | Reserved            |  |  |  |
| 13  | Reserved            |  |  |  |
| 14  | Reserved            |  |  |  |
| 15  | Reserved            |  |  |  |
| 16  | 3_POCL_TIMER_STABLE |  |  |  |
| 17  | 3_POCL_TIMER_STABLE |  |  |  |
| 18  | 3_POCL_TIMER_STABLE |  |  |  |
| 19  | 3_POCL_TIMER_STABLE |  |  |  |
| 20  | 3_POCL_TIMER_STABLE |  |  |  |
| 21  | 3_POCL_TIMER_STABLE |  |  |  |
| 22  | 3_POCL_TIMER_STABLE |  |  |  |
| 23  | 3_POCL_TIMER_STABLE |  |  |  |
| 24  | 3_POCL_TIMER_STABLE |  |  |  |
| 25  | 3_POCL_TIMER_STABLE |  |  |  |
| 26  | 3_POCL_TIMER_STABLE |  |  |  |
| 27  | Reserved            |  |  |  |
| 28  | Reserved            |  |  |  |
| 29  | Reserved            |  |  |  |
| 30  | Reserved            |  |  |  |
| 31  | Reserved            |  |  |  |
|     |                     |  |  |  |

AXN-11-26 BitFlow, Inc. Version A.0

**3\_POCL\_TIMER**\_ R/W, CON201[10..0], Axion-CL OFF

See 0\_POCL\_TIMER\_OFF.

**3\_POCL\_TIMER**\_ R/W, CON201[26..16], Axion-CL STABLE

See 0\_POCL\_TIMER\_STABLE.

CON202 The Axion-CL

# 11.13 CON202

| Bit | Name                    |
|-----|-------------------------|
| 0   | 3_POCL_TIMER_ON         |
| 1   | 3_POCL_TIMER_ON         |
| 2   | 3_POCL_TIMER_ON         |
| 3   | 3_POCL_TIMER_ON         |
| 4   | 3_POCL_TIMER_ON         |
| 5   | 3_POCL_TIMER_ON         |
| 6   | 3_POCL_TIMER_ON         |
| 7   | 3_POCL_TIMER_ON         |
| 8   | 3_POCL_TIMER_ON         |
| 9   | 3_POCL_TIMER_ON         |
| 10  | 3_POCL_TIMER_ON         |
| 11  | Reserved                |
| 12  | Reserved                |
| 13  | Reserved                |
| 14  | Reserved                |
| 15  | Reserved                |
| 16  | 3_POCL_TIMER_DISCONNECT |
| 17  | 3_POCL_TIMER_DISCONNECT |
| 18  | 3_POCL_TIMER_DISCONNECT |
| 19  | 3_POCL_TIMER_DISCONNECT |
| 20  | 3_POCL_TIMER_DISCONNECT |
| 21  | 3_POCL_TIMER_DISCONNECT |
| 22  | 3_POCL_TIMER_DISCONNECT |
| 23  | 3_POCL_TIMER_DISCONNECT |
| 24  | 3_POCL_TIMER_DISCONNECT |
| 25  | 3_POCL_TIMER_DISCONNECT |
| 26  | 3_POCL_TIMER_DISCONNECT |
| 27  | Reserved                |
| 28  | Reserved                |
| 29  | Reserved                |
| 30  | Reserved                |
| 31  | Reserved                |

AXN-11-28 BitFlow, Inc. Version A.0

See 0\_POCL\_TIMER\_ON.

3\_POCL\_TIMER\_ DISCONNECT

R/W, CON202[26..16], Axion-CL

See 0\_POCL\_TIMER\_DISCONNECT.

CON356 The Axion-CL

# 11.14 CON356

| Bit | Name           |
|-----|----------------|
| 0   | FW_BUILD_YEAR  |
| 1   | FW_BUILD_YEAR  |
| 2   | FW_BUILD_YEAR  |
| 3   | FW_BUILD_YEAR  |
| 4   | FW_BUILD_YEAR  |
| 5   | FW_BUILD_YEAR  |
| 6   | FW_BUILD_YEAR  |
| 7   | FW_BUILD_YEAR  |
| 8   | FW_BUILD_YEAR  |
| 9   | FW_BUILD_YEAR  |
| 10  | FW_BUILD_YEAR  |
| 11  | FW_BUILD_YEAR  |
| 12  | FW_BUILD_YEAR  |
| 13  | FW_BUILD_YEAR  |
| 14  | FW_BUILD_YEAR  |
| 15  | Reserved       |
| 16  | FW_BUILD_DAY   |
| 17  | FW_BUILD_DAY   |
| 18  | FW_BUILD_DAY   |
| 19  | FW_BUILD_DAY   |
| 20  | FW_BUILD_DAY   |
| 21  | FW_BUILD_DAY   |
| 22  | FW_BUILD_DAY   |
| 23  | FW_BUILD_DAY   |
| 24  | FW_BUILD_MONTH |
| 25  | FW_BUILD_MONTH |
| 26  | FW_BUILD_MONTH |
| 27  | FW_BUILD_MONTH |
| 28  | FW_BUILD_MONTH |
| 29  | FW_BUILD_MONTH |
| 30  | FW_BUILD_MONTH |
| 31  | FW_BUILD_MONTH |

AXN-11-30 BitFlow, Inc. Version A.0

FW\_BUILD\_ YEAR RO, CON356[15..0], Karbon-CXP, Cyton-CXP

Year that this firmware was compiled in BCD format. Example: 0x2012 is year 2012

FW\_BUILD\_DAY

RO, CON356[23..16], Karbon-CXP, Cyton-CXP

Day that this firmware was compiled in BCD format. Example: 0x18 the 18th of the

month.

FW\_BUILD\_ MONTH RO, CON356[31..24], Karbon-CXP, Cyton-CXP

Month that this firmware was compiled in BCD format. Example: 0x12 is december.

CON357 The Axion-CL

# 11.15 CON357

| Bit | Name          |
|-----|---------------|
| 0   | FW_BUILD_MIN  |
| 1   | FW_BUILD_MIN  |
| 2   | FW_BUILD_MIN  |
| 3   | FW_BUILD_MIN  |
| 4   | FW_BUILD_MIN  |
| 5   | FW_BUILD_MIN  |
| 6   | FW_BUILD_MIN  |
| 7   | FW_BUILD_MIN  |
| 8   | FW_BUILD_HOUR |
| 9   | FW_BUILD_HOUR |
| 10  | FW_BUILD_HOUR |
| 11  | FW_BUILD_HOUR |
| 12  | FW_BUILD_HOUR |
| 13  | FW_BUILD_HOUR |
| 14  | FW_BUILD_HOUR |
| 15  | FW_BUILD_HOUR |
| 16  | FPGA_ID       |
| 17  | FPGA_ID       |
| 18  | FPGA_ID       |
| 19  | FPGA_ID       |
| 20  | FPGA_ID       |
| 21  | FPGA_ID       |
| 22  | FPGA_ID       |
| 23  | FPGA_ID       |
| 24  | FW_CMPTBL     |
| 25  | FW_CMPTBL     |
| 26  | FW_CMPTBL     |
| 27  | FW_CMPTBL     |
| 28  | FW_CMPTBL     |
| 29  | FW_CMPTBL     |
| 30  | FW_CMPTBL     |
| 31  | FW_CMPTBL     |

AXN-11-32 BitFlow, Inc. Version A.0

**FW\_BUILD\_MIN** RO, CON357[7..0], Karbon-CXP, Cyton-CXP

Minute that this firmware was compiled. Example: 0x35 is 35 minutes past the hour.

FW\_BUILD\_ HOUR RO, CON357[15..8], Karbon-CXP, Cyton-CXP

Hour that this firmware was compiled. Example: 0x23 is 11pm (23rd hour).

**FPGA\_ID** RO, CON357[23..16], Karbon-CXP, Cyton-CXP

FPGA Identifier

**FW\_CMPTBL** RO, CON357[31..24], Karbon-CXP, Cyton-CXP

Firmware compatibility version (must match SDK driver internal firmware version).

CON357 The Axion-CL

AXN-11-34 BitFlow, Inc. Version A.0

Specifications Introduction

# **Specifications**

# Chapter 12

#### 12.1 Introduction

This chapter describes the general specifications of the Axion-CL family. The numerical values for he specifications are listed in Table 12-1. If more information is available for a given specification t will be an entry in the column marked "Details".

Table 12-1 Axion-CL Specifications

| Specifications                  | Value              | Units           | Details          |
|---------------------------------|--------------------|-----------------|------------------|
| PCIe Compatibility, slot type   | x4, x8 and x16     | Slot size       | Section 12.2     |
| PCIe Compatibility, generation  | Gen1, 2 and 3      |                 | Section 12.2     |
| Maximum Input CL clock          | 85                 | MHz             |                  |
| Minimum Input CL Rate           | 65                 | MHz             |                  |
| Maximum Pixels Per Line (1 tap) | 10,485,576 (1024K) | Pixels (8-bit)  | Section 12.3     |
| Maximum Lines Per Frame         | 65,536 (64K)       | Lines           | Section 12.4     |
| Minimum trigger pulse           | 10                 | Nanoseconds     |                  |
| Minimum encoder pulse           | 10                 | Nanoseconds     |                  |
| Axion-1xE Current (3.3 Volt)    | ?                  | Amps            | Section 12.5     |
| Axion-1xE Current (12 Volt)     | ?                  | Amps            | Section 12.5     |
| Axion-2xE Current (3.3 Volt)    | 0.75               | Amps            | Section 12.5     |
| Axion2xE Current (12 Volt)      | 0.30               | Amps            | Section 12.5     |
| Temperature range               | 0 to 50            | Degrees Celsius |                  |
| Humidity                        | 25% to 80%         |                 |                  |
| Mechanical dimensions           | 6.8 x 4.2          | Inches          |                  |
| Mechanical dimensions           | 17.4 x 10.6        | Centimeters     |                  |
| Maximum PoCL Power @12 Volts    | 4                  | Watts           | Per CL Connector |
| LVDS Drivers                    | SN65LVDS31D        |                 |                  |
| LVDS Receivers                  | SNLVDS3486         |                 |                  |
| TTL Drivers                     | SN74LVTH241        |                 |                  |
| TTL Receivers                   | SN74LVTH241        |                 |                  |

PCI Express Compatibility

The Axion-CL

## 12.2 PCI Express Compatibility

The Axion-CL is a PCle x4 Gen 2 board. However, it will work in any PCle slot that it fits into. This means it will work in x4, x8 and x16 slots, however, it will also work in x1 slots if these slots are mechanically compatibility with an x4 board, though performance will be greatly degraded. Similarly, the Axion-CL will work in Gen 1, Gen 2 and Gen 3 slot, however, performance will be degraded in a Gen 1 slot. Further, t is no performance gained by putting the Axion-CL in a Gen 3 slot, performance will be the same as a Gen 2 slot.

Note: For best DMA performance, put the Axion-CL in a PCle x4, x8 or x16 Gen 2 or Gen 3 slot on a high quality motherboard.

AXN-12-2 BitFlow, Inc. Version A.0

Specifications Maximum Pixels Per Line

# 12.3 Maximum Pixels Per Line

In most situations, longer line sizes can be accommodated. Please contact BitFlow customer support for more information.

Maximum Lines Per Frame The Axion-CL

# 12.4 Maximum Lines Per Frame

This limitation is for area scan cameras. For line scan cameras, the number of lines per frame is essentially unlimited. Please contact BitFlow customer support for more information.

AXN-12-4 BitFlow, Inc. Version A.0

Specifications Axion Power Requirements

#### 12.5 Axion Power Requirements

The Axion-CL power requirements listed in Table 12-1 are the requirements of the board's circuitry only. In addition, the Axion-CL can provide up to 4 watts of power to each Camera Link connector. The 12 Volt rail of the PCIe bus cannot provide enough power if all CL connector links are drawing maximum power. The board has an auxiliary connector which can be use to provide additional PoCL power for these situations. T is a jumper which is used to switch the power source from the PCIe bus to the auxiliary connector. See Section 12.4 for more information on this jumper.

Note: If the total amount of all cameras connected to the Axion exceeds 15 Watts, then the auxiliary power connector must be used. For example, if two full Camera Link cameras each taking 4 watts perCL connector are connected, then auxiliary power should be used.

Axion Power Requirements

The Axion-CL

Mechanical Introduction

# Mechanical

# Chapter 13

#### 13.1 Introduction

This chapter describes the mechanical characteristics of the Axion-CL This includes description of all of the connectors on the board and pin-outs for these connectors.

The mechanical layout of the Axion-2xE board is shown in Figure 13-1 and the fourth Camera Link Connector is shown in Figure 13-2. The mechanical layout of the Axion-1xE is shown in Figure 13-3.



Figure 13-1 Axion-2xE Board Layout

Introduction The Axion-CL



Figure 13-2 Axion-2xE Fourth CL Connector

AXN-13-2 BitFlow, Inc. Version A.0

Mechanical Introduction



Figure 13-3 Axion-1xE Board Layout

The Axion-CL Connectors

The Axion-CL

#### 13.2 The Axion-CL Connectors

T are eight connectors on the Cyton-CXP4 main board:

BASEO - Camera O, Base connector

MED/FULL0 - Camera 0, Medium/Full connector

BASE1 - Camera 1, Base connector, AXN-PC2-2xE only, mounted on auxiliary connector

MED/FULL1 - Camera 1, Medium/Full connector, AXN-PC2-2xE only

P1 - Connector for I/O Box

P4 - External power connector

P5 - I/O connector

Figure 13-1, Figure 13-2, Figure 13-3 show the locations of these connectors. The following sections show the details of each of these connectors.

#### 13.2.1 The CL Connectors

The CL connectors are for connecting Camera Link cameras. The Axion-CL use SDR connectors. These connectors are fully compliant with the Camera Link version 1.1 and later specification.

Table 13-1 illustrates how to connect the Axion-CL to various types and numbers of Camera Link Cameras.

Table 13-1 Camera Link Connectors - Axion-CL

| Camera(s)             | BASE0          | MED/FULL0      | BASE1          | MED/FULL1      |
|-----------------------|----------------|----------------|----------------|----------------|
| One Base CL Camera    | Camera 0 - CL1 | NC             | NC             | NC             |
| One Medium CL Camera  | Camera 0 - CL1 | Camera 0 - CL2 | NC             | NC             |
| One Full CL Camera    | Camera 0 - CL1 | Camera 0 - CL2 | NC             | NC             |
| One 80-bit CL Camera  | Camera 0 - CL1 | Camera 0 - CL2 | NC             | NC             |
| Two Base CL Cameras   | Camera 0 - CL1 | NC             | Camera 1 - CL1 | NC             |
| Two Medium CL Cameras | Camera 0 - CL1 | Camera 0 - CL2 | Camera 1 - CL1 | Camera 1 - CL2 |
| Two Full CL Cameras   | Camera 0 - CL1 | Camera 0 - CL2 | Camera 1 - CL1 | Camera 1 - CL2 |
| Two 80-bit CL Cameras | Camera 0 - CL1 | Camera 0 - CL2 | Camera 1 - CL1 | Camera 1 - CL2 |

AXN-13-4 BitFlow, Inc. Version A.0

Mechanical Switches

#### 13.3 Switches

T is one piano-type switch block, SW1, on the Axion-CL with two switches. These are used to identify individual boards when t is more than one board in a system. The idea is to set the switches differently on each board in the system. The switch settings can be read for each board from software (by reading the SW bitfield). SysReg also shows the switch setting for each board. See Table 13-2 below shows the switch settings and the corresponding value in the SW bitfield.

Table 13-2 Switch S1 Setting

| SW1.1 | SW1.2 | SW register |
|-------|-------|-------------|
| down  | down  | 0           |
| down  | up    | 1           |
| up    | down  | 2           |
| up    | up    | 3           |

T is one micro switch block, SW3, on the Axion-CL with four switches. These used to control the flash bank that the system boots from.

Note: Do not change these switches unless instructed by BitFlow support.

See Table 13-3 below which shows the switch settings and the corresponding firmware bank.

Table 13-3 Switch S3 Setting

| SW3.4 | SW3.2 | SW 3.2 | SW 3.1 | FW Bank  |
|-------|-------|--------|--------|----------|
| off   | off   | off    | off    | 1        |
| off   | off   | off    | on     | 2        |
| off   | off   | on     | off    | 3        |
| off   | off   | on     | on     | 4        |
| off   | on    | off    | off    | Reserved |
| off   | on    | off    | on     | Reserved |
| off   | on    | on     | off    | Reserved |
| on    | on    | on     | on     | Reserved |
| on    | off   | off    | off    | Reserved |
| on    | off   | off    | on     | Reserved |
| on    | off   | on     | off    | Reserved |
| on    | off   | on     | on     | Reserved |

Switches The Axion-CL

Table 13-3 Switch S3 Setting

| SW3.4 | SW3.2 | SW 3.2 | SW 3.1 | FW Bank  |
|-------|-------|--------|--------|----------|
| on    | on    | off    | off    | Reserved |
| on    | on    | off    | on     | Reserved |
| on    | on    | on     | off    | Reserved |
| on    | on    | on     | on     | Reserved |

AXN-13-6 BitFlow, Inc. Version A.0

Mechanical Jumpers

### 13.4 Jumpers

#### 13.4.1 Jumper JP1

JP1 is used for diagnostic purposed. Please to no make changes to this jumper unless instructed to do so by BitFlow's Customer Support team.

#### 13.4.2 Jumper JP2

T is one user configurable jumper on the Axion-CL, it controls the source of the power that is provided to the Camera Link camera(s) connected to the Axion (PoCL power). Table 13-4 shows the two settings.

Table 13-4 Jumper JP2

| Position | Meaning                                                                                                      |
|----------|--------------------------------------------------------------------------------------------------------------|
| Тор      | PoCL power comes from the PCIe connector. Use when total PoCL power on all connectors is less than 15 watts. |
| Bottom   | PoCL power comes from P4. Use when total PoCL power on all connectors exceeds 15 watts.                      |

If jumper JP2 is in the bottom position, the connector P4 is use to provide PoCL power to the cameras. Contact BitFlow for adapter cables to connect internal PC power to P4.

Note: If the total amount of all cameras connected to the Axion exceeds 15 Watts, then the auxiliary power connector must be used.

LEDs The Axion-CL

# 13.5 LEDs

The Cyton-CXP has 14 LEDs. Table 13-5 Describes the function of these LEDS.

Table 13-5 LEDs

| LED Number | Color   | Function                                     |
|------------|---------|----------------------------------------------|
| D1         | Green   | FPGA Configured                              |
| D3         | Blue    | General purpose, see register LED_BLUE       |
| D4         | Red     | General purpose, see register LED_RED        |
| D5         | Orange  | General purpose, see register LED_ORANGE     |
| D6         | Green   | General purpose, see register LED_GREEN      |
| D5         | Green   | Selectable VFG0 Status, see register SEL_LED |
| D6         | Green   | Selectable VFG1 Status, see register SEL_LED |
| D7         | Green   | Reserved                                     |
| D8         | Green   | Reserved                                     |
| TRILED1    | Various | Camera 1 status                              |
| TRILED2    | Various | Camera 0 status                              |

AXN-13-8 BitFlow, Inc. Version A.0

Mechanical Button

#### 13.6 Button

The Axion-CL has a general purpose button, SW2, that can be routed to many different destinations. The purpose of the button is primarily to help debug I/O problems. It can be used as a trigger, encoder, or I/O that is routed off the board. Please see Section 2.1 for more information on how the button can be routed.

## 13.7 The Auxiliary Power Connector (P4)

For cameras that require more power than can be provide by the PCIe bus, the Axion has a connector, P4, which can take auxiliary power from the PC's power supply. The pin out for this connector is shown in Table 13-6.

Note: Connector P4 is compatible with Berg 4-pin peripheral connectors available in many PCs. This connector is also known as the "floppy connector". For PCs that do have this type of connector, BitFlow offers an adapter cable that goes between P4 and a standard Molex 4-pin peripheral connector available in almost all PCs.

Note: Jumper JP2 must be in set to the correct position to route power from this connector to the Camera Link connectors.

Table 13-6 Auxiliary Power Connector

| Pin | Voltage  |   |
|-----|----------|---|
| 1   | NC       | _ |
| 2   | GND      |   |
| 3   | GND      |   |
| 4   | 12 Volts |   |

AXN-13-10 BitFlow, Inc. Version A.0

Mechanical The I/O Box Connector (P1)

# 13.8 The I/O Box Connector (P1)

This connector is for a I/O break out box the BitFlow will be offering in the future. Please contact BitFlow for more information.

I/O Connector Pinout for the Axion-CL

The Axion-CL

# 13.9 I/O Connector Pinout for the Axion-CL

The pin-out for the I/O Connector (P4) for the Axion-CL is illustrated in the Table 13-7.

Note: Signal names start with the Virtual Frame Grabber (VFG) that they are routed to. For example, the signal VFG0\_TRIGGER\_TTL is wired to VFG0., while VFG2\_TRIGGER\_TTL is wired to VGF2.

Table 13-7 I/O Connector for the Axion-CL

| Pin | I/O | Signal         | Comment |
|-----|-----|----------------|---------|
| 1   | In  | VFG0_TRIGGER+  | LVDS    |
| 2   | In  | VFG0_TRIGGER-  | LVDS    |
| 3   | In  | VFG0_ENCODERA+ | LVDS    |
| 4   | In  | VFG0_ENCODERA- | LVDS    |
| 5   | In  | VFG0_ENCODERB+ | LVDS    |
| 6   | In  | VFG0_ENCODERB- | LVDS    |
| 7   | In  | VFG1_TRIGGER+  | LVDS    |
| 8   | In  | VFG1_TRIGGER-  | LVDS    |
| 9   | In  | VFG1_ENCODERA+ | LVDS    |
| 10  | In  | VFG1_ENCODERA- | LVDS    |
| 11  | In  | VFG1_ENCODERB+ | LVDS    |
| 12  | In  | VFG1_ENCODERB- | LVDS    |
| 13  | In  | VFG2_TRIGGER+  | LVDS    |
| 14  | In  | VFG2_TRIGGER-  | LVDS    |
| 15  | In  | VFG2_ENCODERA+ | LVDS    |
| 16  | In  | VFG2_ENCODERA- | LVDS    |
| 17  | In  | VFG2_ENCODERB+ | LVDS    |
| 18  | In  | VFG2_ENCODERB- | LVDS    |
| 19  | In  | VFG3_TRIGGER+  | LVDS    |
| 20  | In  | VFG3_TRIGGER-  | LVDS    |
| 21  | In  | VFG3_ENCODERA+ | LVDS    |
| 22  | In  | VFG3_ENCODERA- | LVDS    |
| 23  | In  | VFG3_ENCODERB+ | LVDS    |
| 24  | In  | VFG3_ENCODERB- | LVDS    |
| 25  |     | GND            |         |
| 26  | Out | VFG0_CC3+      | LVDS    |
| 27  | Out | VFG0_CC3-      | LVDS    |
| 28  | Out | VFG1_CC3+      | LVDS    |
| 29  | Out | VFG1_CC3-      | LVDS    |
| 30  | Out | VFG2_CC3+      | LVDS    |
| 31  | Out | VFG2_CC3-      | LVDS    |
| 32  | Out | VFG3_CC3+      | LVDS    |

AXN-13-12 BitFlow, Inc. Version A.0

Table 13-7 I/O Connector for the Axion-CL

| Pin | I/O | Signal            | Comment |
|-----|-----|-------------------|---------|
| 33  | Out | VFG3_CC3-         | LVDS    |
| 34  |     | GND               |         |
| 35  | In  | VFG0_TRIGGER_TTL  | TTL     |
| 36  | In  | VFG0_ENCODERA_TTL | TTL     |
| 37  | In  | VFG0_ENCODERB_TTL | TTL     |
| 38  | In  | VFG1_TRIGGER_TTL  | TTL     |
| 39  | In  | VFG1_ENCODERA_TTL | TTL     |
| 40  | In  | VFG1_ENCODERB_TTL | TTL     |
| 41  | In  | VFG2_TRIGGER_TTL  | TTL     |
| 42  | In  | VFG2_ENCODERA_TTL | TTL     |
| 43  | In  | VFG2_ENCODERB_TTL | TTL     |
| 44  | In  | VFG3_TRIGGER_TTL  | TTL     |
| 45  | In  | VFG3_ENCODERA_TTL | TTL     |
| 46  | In  | VFG3_ENCODERB_TTL | TTL     |
| 47  |     | Reserved          |         |
| 48  | Out | VFG0_CC3_TTL      | TTL     |
| 49  | Out | VFG0_CC4_TTL      | TTL     |
| 50  | Out | VFG0_CC2_TTL      | TTL     |
| 51  | Out | VFG1_CC3_TTL      | TTL     |
| 52  | Out | VFG1_CC4_TTL      | TTL     |
| 53  | Out | VFG1_CC2_TTL      | TTL     |
| 54  | Out | VFG2_CC3_TTL      | TTL     |
| 55  | Out | VFG2_CC4_TTL      | TTL     |
| 56  | Out | VFG2_CC2_TTL      | TTL     |
| 57  | Out | VFG3_CC3_TTL      | TTL     |
| 58  | Out | VFG3_CC4_TTL      | TTL     |
| 59  | Out | VFG3_CC2_TTL      | TTL     |
| 60  |     | GND               |         |

# Index

# **Numerics**

0 CL CLOCK DETECTED AXN-11-3 0 CL CLOCK LOST LATCH AXN-11-3 0\_ENABLE\_POCL\_SYSTEM AXN-11-4 0 POCL EN CAM SENSE AXN-11-3 0 POCL EN POWER AXN-11-3 0\_POCL\_HW\_DIS AXN-11-3 0 POCL OPEN DETECTED AXN-11-3 0 POCL OVER DETECTED AXN-11-3 0\_POCL\_OVER\_LATCH AXN-11-3 0 POCL OVR AUTO RESTART AXN-11-3 0\_POCL\_SENSE\_BYPASS AXN-11-4 0\_POCL\_STATE AXN-11-3 0 POCL TIMER DISCONNECT AXN-11-8 0\_POCL\_TIMER\_OFF AXN-11-6 0\_POCL\_TIMER\_ON AXN-11-8 0 POCL TIMER STABLE AXN-11-6 1 CL CLOCK DETECTED AXN-11-10 1\_CL\_CLOCK\_LOST\_LATCH AXN-11-10 1 ENABLE POCL SYSTEM AXN-11-11 1\_POCL\_EN\_CAM\_SENSE AXN-11-10 1 POCL EN POWER AXN-11-10 1 POCL HW DIS AXN-11-10 1\_POCL\_OPEN\_DETECTED AXN-11-10 1\_POCL\_OVER\_DETECTED AXN-11-10 1 POCL OVER LATCH AXN-11-10 1\_POCL\_OVR\_AUTO\_RESTART\_AXN-11-10 1\_POCL\_SENSE\_BYPASS AXN-11-11 1 POCL STATE AXN-11-10 1\_POCL\_TIMER\_DISCONNECT AXN-11-15 1 POCL TIMER OFF AXN-11-13 1 POCL TIMER ON AXN-11-15 1 POCL TIMER STABLE AXN-11-13 2\_CL\_CLOCK\_DETECTED AXN-11-17 2 CL CLOCK LOST LATCH AXN-11-17 2 ENABLE POCL SYSTEM AXN-11-18 2\_POCL\_EN\_CAM\_SENSE AXN-11-17 2\_POCL\_EN\_POWER AXN-11-17 2 POCL HW DIS AXN-11-17 2\_POCL\_OPEN\_DETECTED AXN-11-17 2 POCL OVER DETECTED AXN-11-17 2 POCL OVER LATCH AXN-11-17 2\_POCL\_OVR\_AUTO\_RESTART AXN-11-17 2 POCL SENSE BYPASS AXN-11-18 2 POCL STATE AXN-11-17

2 POCL TIMER DISCONNECT AXN-11-22 2 POCL TIMER OFF AXN-11-20 2\_POCL\_TIMER\_ON AXN-11-22 2 POCL TIMER STABLE AXN-11-20 3 CL CLOCK DETECTED AXN-11-24 3\_CL\_CLOCK\_LOST\_LATCH AXN-11-24 3 ENABLE POCL SYSTEM AXN-11-25 3 POCL EN CAM SENSE AXN-11-24 3\_POCL\_EN\_POWER AXN-11-24 3 POCL HW DIS AXN-11-24 3\_POCL\_OPEN\_DETECTED AXN-11-24 3\_POCL\_OVER\_DETECTED AXN-11-24 3 POCL OVER LATCH AXN-11-24 3\_POCL\_OVR\_AUTO\_RESTART\_AXN-11-24 3 POCL SENSE BYPASS AXN-11-25 3 POCL STATE AXN-11-24 3 POCL TIMER DISCONNECT AXN-11-29 3 POCL TIMER OFF AXN-11-27 3 POCL TIMER ON AXN-11-29 3\_POCL\_TIMER\_STABLE AXN-11-27

# A

ADDR CL CON BASE AXN-10-12 ADDR\_ENCA\_FILTER AXN-6-23 ADDR ENCB FILTER AXN-6-25 ADDR\_FLASH\_ADDR\_BASE AXN-10-23 ADDR FLASH CON BASE AXN-10-20 ADDR FLASH DAT BASE AXN-10-25 ADDR\_TAP\_CON\_BASE AXN-10-14 ADDR\_TAP\_TABLE\_ADDR\_BASE AXN-10-16 ADDR TAP TABLE DAT BASE AXN-10-18 ADDR\_TRIG\_FILTER AXN-6-21 ADDR\_UART\_CON\_BASE AXN-10-7 ADDR\_UART\_RDAT\_BASE AXN-10-10 AE CON AXN-2-8 AE FIFO OVERFLOW AXN-2-11 AE RUN LEVEL AXN-2-9 AE STATE AXN-2-11 AE\_STATUS AXN-2-10 AE STREAM SEL AXN-2-12 ALIGN AUTO EN AXN-10-6 ALIGN\_MANUAL\_DELAY AXN-10-5 ALIGN\_MANUAL\_EN AXN-10-5 ALIGN MANUAL LOCK AXN-10-5 ALIGN\_MANUAL\_RST AXN-10-5

### Axion Camera Configuration Files AXN-1-8

#### В

BFML AXN-1-8
BFML documentation AXN-1-8
BITFIELDNAME AXN-P-3
BM\_QUADS\_CACHED AXN-3-27
BM\_RUN\_LEVEL AXN-3-8
BM\_STATE AXN-3-27
BOARD\_CONFIG AXN-3-11
BUF\_MGR\_CON AXN-3-7
BUF\_MGR\_STATUS AXN-3-26
BUF\_MGR\_TIMEOUT AXN-3-9
Button AXN-13-9

#### C

Camera Link AXN-1-1 Camera Link Camera Power (PoCL) AXN-1-6 CL CHAN CONFIG AXN-10-4 CL\_CHAN\_EN AXN-10-13 CL\_IOBUF\_CTL AXN-10-2 CL LVAL POS AXN-10-13 CL MODE AXN-10-13 CL USE DVAL AXN-10-13 CL USE FVAL AXN-10-13 CON104 AXN-11-2 CON105 AXN-11-5 CON106 AXN-11-7 CON136 AXN-11-9 CON137 AXN-11-12 CON138 AXN-11-14 CON168 AXN-11-16 CON169 AXN-11-19 CON170 AXN-11-21 CON200 AXN-11-23 CON201 AXN-11-26 CON202 AXN-11-28 CON356 AXN-11-30 CON357 AXN-11-32 CON485 AXN-3-3 CON486 AXN-3-5 CON489 AXN-2-38 CON490 AXN-2-41 CON548 AXN-2-43 CON549 AXN-2-46 CON60 AXN-6-2 CON61 AXN-6-4

CON62 AXN-6-6

CON63 AXN-6-10
CON64 AXN-6-15
CON65 AXN-9-2
CON66 AXN-9-4
CON67 AXN-9-8
CON68 AXN-9-11
CON69 AXN-9-13
CPL\_ERROR AXN-3-28
CPL\_STATUS AXN-3-27
CPLD\_MODE AXN-3-12
CPLD\_STRAP AXN-3-12
CURR\_FETCH\_SIZE AXN-3-8

#### D

DISABLE\_PKT\_FLUSH\_TIMER AXN-3-30 DISABLE\_PKT\_GEN AXN-3-30 DISABLE\_TIMEOUT AXN-3-10 DST\_ADDR\_ERROR\_LSB AXN-3-27

#### E

EN\_ENCA AXN-6-8
EN\_ENCB AXN-6-8
EN\_TRIG AXN-6-8
ENC\_DIV\_FCLK\_SEL AXN-9-10
ENC\_DIV\_M AXN-9-3
ENC\_DIV\_N AXN-9-3
ENC\_DIV\_OPEN\_LOOP AXN-9-10
ENCA\_POL AXN-6-18
ENCB\_FILTER AXN-6-26
ENCB\_POL AXN-6-18
Encoder Divider AXN-7-1
ENINT\_ALL AXN-2-42
ENINT\_CXP AXN-6-3

#### F

FIRST\_QUAD\_PTR\_HI AXN-3-6
FIRST\_QUAD\_PTR\_LO AXN-3-4
FLASH\_ADDR AXN-10-24
FLASH\_BULK\_ERASE AXN-10-21
FLASH\_BUSY AXN-10-22
FLASH\_CODE AXN-10-21
FLASH\_DATA\_IN AXN-10-26
FLASH\_DATA\_OUT AXN-10-26
FLASH\_DATA\_VALID AXN-10-22
FLASH\_EN4B\_ADDR AXN-10-22
FLASH\_EX4B\_ADDR AXN-10-22
FLASH\_ILLEGAL\_ERASE AXN-10-22

FLASH ILLEGAL WRITE AXN-10-22 FLASH READ AXN-10-21 FLASH\_READ\_RDID AXN-10-22 FLASH\_READ\_STATUS AXN-10-22 FLASH RESET AXN-10-21 FLASH\_SECTOR\_ERASE AXN-10-21 FLASH\_SECTOR\_PROTECT AXN-10-21 FLASH SHIFTBYTE AXN-10-21 FLASH\_WRITE AXN-10-21 FPGA ID AXN-11-33 FW BUILD DAY AXN-11-31 FW\_BUILD\_HOUR AXN-11-33 FW BUILD MIN AXN-11-33 FW BUILD MONTH AXN-11-31 FW\_BUILD\_YEAR AXN-11-31 FW CMPTBL AXN-11-33

#### G

GPOUTO AXN-6-18 GPOUT1 AXN-6-18 GPOUT10 AXN-6-19 GPOUT11 AXN-6-19 GPOUT2 AXN-6-18 GPOUT3 AXN-6-18 GPOUT4 AXN-6-19 GPOUT5 AXN-6-19 GPOUT6 AXN-6-19 GPOUT7 AXN-6-19 GPOUT8 AXN-6-19 GPOUT9 AXN-6-19

#### ı

I/O Connector Pinout the Axion-CL AXN-13-12 INT\_AE\_LOSS\_OF\_SYNC AXN-2-40 INT AE LOSS OF SYNC M AXN-2-45 INT\_AE\_LOSS\_OF\_SYNC\_WP AXN-2-48 INT ANY AXN-2-42 INT BM ERROR AXN-2-39 INT\_BM\_ERROR\_M AXN-2-44 INT BM ERROR WP AXN-2-47 INT CXP AXN-6-3 INT\_ENC\_A AXN-2-39 INT ENC A M AXN-2-44 INT\_ENC\_A\_WP AXN-2-47 INT\_ENC\_B AXN-2-39 INT ENC B M AXN-2-44 INT\_ENC\_B\_WP AXN-2-47 INT\_PCIE\_PKT\_DROPPED AXN-2-40

INT PCIE PKT DROPPED M AXN-2-45 INT PCIE PKT DROPPED WP AXN-2-48 INT\_TRIG AXN-2-39 INT TRIG M AXN-2-44 INT TRIG WP AXN-2-47 INT\_V\_ACQUIRED AXN-2-39 INT\_V\_ACQUIRED\_M AXN-2-44 INT V ACQUIRED WP AXN-2-47 INT\_V\_START\_M AXN-2-44 INT\_V\_START\_WP AXN-2-47 INT Y ACQUIRED AXN-2-39 INT\_Y\_ACQUIRED\_M AXN-2-44 INT Y ACQUIRED WP AXN-2-47 INT Y START M AXN-2-44 INT\_Y\_START\_WP AXN-2-47 INT Z ACQUIRED AXN-2-39 INT Z ACQUIRED LEGACY AXN-2-40 INT\_Z\_ACQUIRED\_LEGACY\_M AXN-2-45 INT Z ACQUIRED LEGACY WP AXN-2-48 INT\_Z\_ACQUIRED\_M AXN-2-44 INT\_Z\_ACQUIRED\_WP AXN-2-47 INT\_Z\_START\_M AXN-2-44 INT\_Z\_START\_WP AXN-2-47 IOBUF\_BUSY AXN-10-3 **IOBUF CHAN AXN-10-3 IOBUF LANE AXN-10-3 IOBUF SETTING AXN-10-3 IOBUF WRITE AXN-10-3** 

#### J

Jumper JP1 AXN-13-7 Jumper JP2 AXN-13-7 Jumpers AXN-13-7

#### L

LED\_GREEN AXN-6-20 LED\_ORANGE AXN-6-19 LED\_RED AXN-6-19

#### M

MAX\_FETCH\_SIZE AXN-3-8 MAX\_PAYLOAD\_PCIE AXN-3-30 MAX\_PAYLOAD\_USER\_AXN-3-30

#### N

NEW\_FRAME\_RESYNC AXN-3-20 NEXT ADDR ERROR LSB AXN-3-27 NO\_QUAD\_AVAIL AXN-3-20 NUM\_PACKETS\_DROP AXN-3-14 NUM\_PACKETS\_SENT AXN-3-14 NUM\_QTABS\_LOADED AXN-3-25 NUM\_QTABS\_USED AXN-3-18 NUM\_QUADS\_LOADED AXN-3-23 NUM\_QUADS\_USED AXN-3-16

#### P

PACKETS\_SENT\_STATUS AXN-3-13
PKT\_CON AXN-3-29
PKT\_FLUSH\_ENABLE AXN-3-21
PKT\_STAT AXN-3-19
PKT\_STATE AXN-3-20
PLL\_ADJUST\_PLL\_PHASE AXN-10-5
PLL\_CHAN AXN-10-6
PLL\_CONFIG\_BUSY AXN-10-6
PLL\_CONFIG\_ERROR AXN-10-5
PLL\_PLL\_PHASE\_DIR AXN-10-5
PLL\_RST AXN-10-5
PoCL power AXN-13-7

# Q

QENC AQ DIR AXN-9-5 QENC COUNT AXN-9-14 QENC DECODE AXN-9-5 QENC\_DIR AXN-9-14 QENC DUAL PHASE AXN-9-6 QENC INTRVL IN AXN-9-14 QENC\_INTRVL\_LL AXN-9-5 QENC\_INTRVL\_MODE AXN-9-5 QENC\_INTRVL\_UL AXN-9-9 QENC\_NEW\_LINES AXN-9-15 QENC\_NO\_REAQ AXN-9-5 QENC PHASEA AXN-9-12, AXN-9-14 QENC\_PHASEB AXN-9-14, AXN-9-15 QENC REAQ MODE AXN-9-9 QENC RESET AXN-9-7 QENC\_RESET\_REAQ\_AXN-9-9 QTABS LOADED STATUS AXN-3-24 QTABS\_USED\_STATUS AXN-3-17 QUAD\_COMPLETE\_TIMEOUT AXN-3-10 QUAD DROPPED AXN-3-20 QUAD\_FIFO\_OVERFLOW AXN-3-28 QUAD\_NUM\_MISMATCH AXN-3-28 QUAD TIMEOUT DETECTED AXN-3-28 QUADS\_LOADED\_STATUS AXN-3-22 QUADS\_USED\_STATUS AXN-3-15

#### R

R/W AXN-P-4 RD\_BOX\_IN\_DIF AXN-6-3 RD\_BOX\_IN\_OPTO AXN-6-5 RD BOX IN TTL AXN-6-3, AXN-6-24 RD\_BUTTON AXN-6-8 RD\_CXP\_IO\_IN AXN-6-8 RD\_CXP\_IO\_OUT AXN-6-5 RD CXP TRIG IN AXN-6-8 RD\_CXP\_TRIG\_OUT AXN-6-5 RD ENCA DIF AXN-6-7 RD ENCA SELECTED AXN-6-9 RD\_ENCA\_SW AXN-6-7 RD ENCA TTL AXN-6-7 RD ENCA VFG0 AXN-6-7 RD\_ENCB\_DIF AXN-6-8 RD\_ENCB\_SELECTED AXN-6-8 RD\_ENCB\_SW AXN-6-8 RD\_ENCB\_TTL AXN-6-7 RD ENCB VFG0 AXN-6-8 RD\_ENCQ\_SELECTED AXN-9-12 RD\_ON\_EMPTY AXN-3-20 RD SCAN STEP AXN-6-7 RD SW TRIG AXN-6-7 RD\_TRIG\_DIF AXN-6-7 RD TRIG SELECTED AXN-6-9 RD\_TRIG\_TTL AXN-6-7 RD\_TRIG\_VFG0 AXN-6-7 RO AXN-P-4 RS232\_BAUD\_RATE AXN-10-8 RS232\_RX\_DATA AXN-10-11 RS232 RX FIFO CLEAR AXN-10-8 RS232\_RX\_INT\_ENABLE AXN-10-8 RS232\_RX\_INVERT\_AXN-10-8 RS232\_RX\_LEVEL AXN-10-8 RS232\_RX\_OVERFLOW AXN-10-8 RS232\_RX\_REQ\_AXN-10-8 RS232\_TX\_DATA AXN-10-8 RS232 TX GO AXN-10-8 RS232\_TX\_INVERT\_AXN-10-8 RS232 TX READY AXN-10-9

# S

SCAN\_STEP AXN-9-3 SCAN\_STEP\_TRIG AXN-9-6 SEL\_BOX\_OUT\_DIF AXN-6-17 SEL\_BOX\_OUT\_OPTO AXN-6-17 SEL\_BOX\_OUT\_TTL AXN-6-17 SEL CC1 AXN-6-13 TRIGPOL AXN-6-18 SEL CC2 AXN-6-13 TS AXN-4-1 SEL\_CC3 AXN-6-16 TS\_CONDITION AXN-4-10 SEL CC4 AXN-6-16 TS CONTROL AXN-4-3 SEL ENCA AXN-6-11 TS COUNT AXN-4-9 SEL\_ENCB AXN-6-12 TS\_CT0\_DEFAULT\_STATE AXN-4-4 SEL\_ENCDIV AXN-9-3 TS\_CT1\_DEFAULT\_STATE AXN-4-4 SEL ENCDIV INPUT AXN-9-3 TS\_CT2\_DEFAULT\_STATE AXN-4-4 SEL\_ENCQ AXN-9-3 TS\_CT3\_DEFAULT\_STATE AXN-4-4 SEL LED AXN-6-14 TS END OF SEQUENCE AXN-4-10 SEL TRIG AXN-6-11 TS IDX ACCESS AXN-4-7 SF\_CON AXN-2-51 TS\_IDX\_JUMP AXN-4-4 SF DIM AXN-2-49 TS NEXT AXN-4-9 TS RESOLUTION AXN-4-9 SF HEIGHT AXN-2-50 SF\_INC\_X AXN-2-53 TS\_RUN\_LEVEL AXN-4-4, AXN-4-5 SF INC Y AXN-2-53 TS STATE CT0 AXN-4-9 SF INC Z AXN-2-53 TS\_STATE\_CT1 AXN-4-9 SF\_INIT\_BYTE AXN-2-52 TS\_STATE\_CT2 AXN-4-9 SF LINE SCAN AXN-2-52 TS STATE CT3 AXN-4-9 SF\_MODE AXN-2-52 TS\_TABLE\_CONTROL AXN-4-6 SF\_RUN\_LEVEL AXN-2-52 TS\_TABLE\_ENTRY AXN-4-8 SF STATE AXN-2-52 TS\_TERMINATE AXN-4-10 SF WIDTH AXN-2-50 TS\_TRIG\_SEL AXN-4-5 SF\_X\_GAP AXN-2-52 SF Y GAP AXN-2-53 U SF Z GAP AXN-2-53 USE\_SYNTHETIC\_FRAME AXN-2-13 SIZE ERROR LSB AXN-3-27 SIZE ERROR MSB AXN-3-27 Specifications AXN-12-1 STREAM\_SEL AXN-2-13 V ACQ COUNT AXN-2-31 SW AXN-3-12 V\_ACQ\_COUNT\_CLR\_MODE AXN-2-31, AXN-SW\_ENCA AXN-6-3 2-35 SW\_ENCB AXN-6-3 V ACQUIRED AXN-2-30 SW TRIG AXN-6-3 V\_SIZE AXN-2-15 Switches AXN-13-5 V\_WIN\_DIM AXN-2-14 VFG AXN-1-1 T VIDEO\_DROPPED AXN-3-20 TAP\_DATA AXN-10-19 W TAP\_FIXED\_VAL AXN-10-15 TAP\_MODE AXN-10-15

TAP\_DATA AXN-10-19
TAP\_FIXED\_VAL AXN-10-15
TAP\_MODE AXN-10-15
TAP\_OUTPUT\_16 AXN-10-15
TAP\_TABLE\_INDEX AXN-10-17
TAP\_TABLE\_OFFS AXN-10-17
TAP\_TABLE\_TYPE AXN-10-17
The Stream Sync DMA Engine AXN-1-6
The Timing Sequencer Signal Generator AXN-1-5
Timing Sequencer AXN-4-1
TRIG FILTER AXN-6-22, AXN-6-24, AXN-6-26

WO AXN-P-4 WR\_ON\_FULL AXN-3-20

#### X

X\_ACQ\_COUNT AXN-2-37 X\_ACQ\_COUNT\_CLR\_MODE AXN-2-37 X\_ACQUIRED AXN-2-36 X\_OFFS AXN-2-29 X\_SIZE AXN-2-29

### X\_WIN\_DIM AXN-2-28

#### Y

Y\_ACQ\_COUNT AXN-2-35
Y\_ACQUIRED AXN-2-34
Y\_CLOSE AXN-2-23
Y\_CLOSE\_TRIG\_FUNC AXN-2-23
Y\_CLOSE\_TRIG\_SEL AXN-2-23
Y\_OFFS AXN-2-27
Y\_OPEN\_TRIG\_FUNC AXN-2-24
Y\_OPEN\_TRIG\_SEL AXN-2-24
Y\_SIZE AXN-2-27
Y\_SYNC AXN-2-25
Y\_WIN\_CON AXN-2-22
Y\_WIN\_DIM AXN-2-26

# Z

Z\_ACQ\_COUNT AXN-2-33
Z\_ACQ\_COUNT\_CLR\_MODE AXN-2-33
Z\_ACQUIRED AXN-2-32
Z\_CLOSE AXN-2-17
Z\_CLOSE\_TRIG\_FUNC AXN-2-17
Z\_CLOSE\_TRIG\_SEL AXN-2-17
Z\_OFFS AXN-2-21
Z\_OPEN AXN-2-18, AXN-2-24
Z\_OPEN\_TRIG\_FUNC AXN-2-18
Z\_OPEN\_TRIG\_SEL AXN-2-18
Z\_SIZE AXN-2-21
Z\_SYNC AXN-2-19
Z\_WIN\_CON AXN-2-16
Z\_WIN\_DIM AXN-2-20