# LWA352 SNAP2 F-Engine Documentation

Release 1.0.0

**Jack Hickish** 

# **CONTENTS:**

| 1  |       | ıllation                      | 3  |
|----|-------|-------------------------------|----|
|    | 1.1   | Get the Source Code           | 3  |
|    | 1.2   | Install Prerequisites         | 3  |
| 2  | Cont  | trol Interface                | 5  |
|    | 2.1   | Overview                      | 5  |
|    | 2.2   | SNAP2Fengine Python Interface | 6  |
|    | 2.3   | etcd Interface                | 24 |
| 3  | F-En  | agine Register Definitions    | 29 |
|    | 3.1   | Register Descriptions         | 29 |
| 4  | Indic | ces and tables                | 37 |
| In | dex   |                               | 39 |

Contents:

CONTENTS: 1

2 CONTENTS:

**CHAPTER** 

ONE

# INSTALLATION

The LWA 352 F-Engine pipeline is available at https://github.com/realtimeradio/caltech-lwa. Follow the following instructions to download and install the pipeline.

Specify the build directory by defining the BUILDDIR environment variable, eg:

```
export BUILDDIR=~/src/mkdir -p $BUILDDIR
```

# 1.1 Get the Source Code

Clone the repository and its dependencies with:

```
# Clone the main repository
cd $BUILDDIR
git clone https://github.com/realtimeradio/caltech-lwa
# Clone relevant submodules
cd caltech-lwa
git submodule init
git submodule update
```

# 1.2 Install Prerequisites

# 1.2.1 Firmware Requirements

The LWA-253 F-Engine firmware can be built with the CASPER toolflow, and was designed using the following software stack:

- Ubuntu 18.04.0 LTS (64-bit)
- MATLAB R2019a
- Simulink R2019a
- MATLAB Fixed-Point Designer Toolbox R2019a
- Xilinx Vivado HLx 2019.1.3
- Python 3.6.9

It is *strongly* recommended that the same software versions be used to rebuild the design.

# **CONTROL INTERFACE**

# 2.1 Overview

A Python class Snap2Fengine is provided to encapsulate control of individual blocks in the firmware DSP pipeline. The structure of the software interface aims to mirror the hierarchy of the firmware modules, through the use of multiple Block class instances, each of which encapsulates control of a single module in the firmware pipeline.

In testing, and interactive debugging, the Snap2Fengine class provides an easy way to probe board status for a SNAP2 board on the local network.

In order to integrate with the larger LWA352 control framework, control and monitoring of multiple F-Engines can also be carried out through the passing of JSON-encoded messages through an etcd<sup>1</sup> key-value store. This mechanismi, shown in Fig. 2.1, utilizes the Python class Snap2FengineEtcdClient to translate commands and responses between the etcd format and the underlying Snap2Fengine method calls.



Fig. 2.1: The top-level control architecture.

<sup>&</sup>lt;sup>1</sup> See etcd.io

# 2.2 SNAP2Fengine Python Interface

# 2.2.1 Top-Level Control

**class** lwa\_f.snap2\_fengine.**Snap2Fengine**(*host*, *logger=None*)
A control class for LWA352's SNAP2 F-Engine firmware.

#### **Parameters**

- host (casperfpga.CasperFpga) CasperFpga interface for host.
- logger (logging.Logger) Logger instance to which log messages should be emitted.

configure\_output (base\_ant, n\_chans\_per\_packet, chans, ips, ports=None)

Configure channel reordering and packetizer modules to emit a selection of frequency channels.

# **Parameters**

- **base\_ant** (*int*) Antenna ID which should be written to output packet headers. In general this should be the first antenna on this F-engine board.
- n\_chans\_per\_packet (int) Number of channels per packet.
- chans (list of int) A list of channel indices to be sent, e.g. range(0, 1024). The number of channels in this list should be an integer multiple of n\_chans\_per\_packet. An assertion error is raised if this is not the case.
- ips (list of str) A list of IP addresses to which packets should be sent. The order of values in ips and chans should reflect where different channels should be sent. The n th IP address in ips is the destination to which channels chans[n\*n\_chans\_per\_packet: (n+1)\*n\_chans\_per\_packet] should be sent. As such, ips should have len(chans) // n\_chans\_per\_packet elements. IP addresses should be provided in dotted-quad string representation.
- ports (list of int) The UDP destination ports to which packets should be transmitted. Addressing rules are the same as for ips. If None, all packets are transmitted to UDP port 10000.

# get\_status\_all()

Call the get status methods of all blocks in self.blocks.

**Returns** The contents of the underlying get\_status calls, in a dictionary keyed by the names of the blocks in self.blocks.

#### hostname

hostname of the F-Engine's host SNAP2 board

# initialize (read\_only=True)

Call the `initialize methods of all underlying blocks.

**Parameters read\_only** (bool) – If True, call the underlying initialization methods in a read\_only manner.

# logger

Python Logger instance

# print\_status\_all (use\_color=True)

Print the status returned by get\_status for all blocks in the system.

**Parameters use color** (bool) – If True, highlight values with colors based on error codes.

# program (fpgfile, force=False)

Program an .fpg file to a SNAP2 FPGA. If the name of the file matches what is already in flash, this command will simply reboot the FPGA. If the name of the file doesn't match, the new bitstream will be uploaded. This will take <=5 minutes.

### **Parameters**

- **fpqfile** (str) The .fpg file to be loaded. Should be a path to a valid .fpg file.
- **force** (boolean) If True, write the firmware to flash even if the SNAP claims it is already loaded.

# 2.2.2 FPGA Control

**class** lwa\_f.blocks.fpga.**Fpga** (*host*, *name*, *logger=None*)

Instantiate a control interface for top-level FPGA control.

#### **Parameters**

- host (casperfpga. CasperFpga) CasperFpga interface for host.
- name (str) Name of block in Simulink hierarchy.
- logger (logging.Logger) Logger instance to which log messages should be emitted.

# get\_build\_time()

Read the UNIX time at which the current firmware was built.

Return build\_time Seconds since the UNIX epoch at which the running firmware was built.

# Rtype int

# get\_firmware\_version()

Read the firmware version register and return the contents as a string.

**Return version** major\_version.minor\_version.revision.bugfix

# Rtype str

# get\_status()

Get status and error flag dictionaries.

#### Status keys:

- programmed (bool): True if FPGA appears to be running DSP firmware. False otherwise, and flagged as a warning.
- flash\_firmware (str): The name of the firmware file currently loaded in flash memory.
- flash\_firmware\_md5 (str): The MD5 checksum of the firmware file currently loaded in flash memory.
- timestamp (str): The current time, as an ISO format string.
- serial (str): The serial number / identifier for this board. Flagged with a warning if no serial is available.
- host (str): The host name of this board.
- sw\_version (str): The version string of the control software package. Flagged as warning if the version indicates a build against a dirty git repository.
- fw\_version (str): The version string of the currently running firmware. Available only if the board is programmed.

- fw\_build\_time (int): The build time, in seconds since the UNIX epoch. Available only if the board is programmed.
- sys\_mon (str): 'reporting' if the current firmware has a functioning system monitor module. Otherwise 'not reporting', flagged as an error.
- temp (float): FPGA junction temperature, in degrees C. (Only reported is system monitor is available). Flagged as a warning if outside the recommended operating conditions. Flagged as an error if outside the absolute maximum ratings. See DS892.
- vccaux (float): Voltage of the VCCAUX FPGA power rail. (Only reported is system monitor is available). Flagged as a warning if outside the recommended operating conditions. Flagged as an error if outside the absolute maximum ratings. See DS892.
- vccbram (float): Voltage of the VCCBRAM FPGA power rail. (Only reported is system monitor is available). Flagged as a warning if outside the recommended operating conditions. Flagged as an error if outside the absolute maximum ratings. See DS892.
- vccint (float): Voltage of the VCCINT FPGA power rail. (Only reported is system monitor is available). Flagged as a warning if outside the recommended operating conditions. Flagged as an error if outside the absolute maximum ratings. See DS892.

**Returns** (status\_dict, flags\_dict) tuple. *status\_dict* is a dictionary of status key-value pairs. flags\_dict is a dictionary with all, or a sub-set, of the keys in *status\_dict*. The values held in this dictionary are as defined in *error\_levels.py* and indicate that values in the status dictionary are outside normal ranges.

#### is programmed()

Lazy check to see if a board is programmed. Check for the "version\_version" register. If it exists, the board is deemed programmed.

**Returns** True if programmed, False otherwise.

Return type bool

# 2.2.3 Timing Control

```
class lwa_f.blocks.sync.Sync(host, name, logger=None)

arm_noise()
    Arm noise generator resets

arm_sync()
    Arm sync pulse generator.

count_ext()

    Returns Number of external sync pulses received.
    Rtype int

count_int()

    Returns Number of internal sync pulses received.

    Rtype int

get_error_count()

    Returns Number of sync errors.
```

# Rtype int

# get\_latency()

Returns Number of FPGA clock ticks between sync transmission and reception

# Rtype int

#### get status()

Get a dictionary of status values, with optional warning of error flags. To be overridden by individual blocks

**Returns** (status\_dict, flags\_dict) tuple. *status\_dict* is a dictionary of status key-value pairs, defined on a per-block basis. flags\_dict is a dictionary with all, or a sub-set, of the keys in *status\_dict*. The values held in this dictionary should be as defined in *error\_levels.py*.

## initialize(read\_only=False)

Initialize block.

**Parameters read\_only** (bool) – If False, initialize system control register to 0 and reset error counters. If True, do nothing.

# load\_telescope\_time (tt, software\_load=False)

Load a new starting value into the telescope time counter on the next sync.

### **Parameters**

- tt (int) Telescope time to load
- **software\_load** (bool) If True, immediately load via a software trigger. Else load on the next external sync pulse arrival.

# period()

**Returns** The number of FPGA clock ticks between the last two external sync pulses.

# Rtype int

# reset\_error\_count()

Reset internal error counter to 0.

# reset\_telescope\_time()

Reset the telescope time counter to 0 immediately.

# sw\_sync()

Issue a software sync pulse

# uptime()

**Returns** Time in FPGA clock ticks since the FPGA was last programmed. Resolution is 2\*\*32 (21 seconds at 200 MHz)

# Return type int

# wait\_for\_sync()

Block until a sync has been received.

# 2.2.4 ADC Control

class lwa\_f.blocks.adc.Adc(host, name, logger=None)

Instantiate a control interface for an ADC block.

#### **Parameters**

- host (casperfpga. CasperFpga) CasperFpga interface for host.
- name (str) Name of block in Simulink hierarchy.
- logger (logging.Logger) Logger instance to which log messages should be emitted.

# calibrate (use\_ramp=False)

Compute and set all ADC data lane input delays to their optimal values. After this call, the ADCs are left in test mode.

**Parameters use\_ramp** (bool) – If True, after calibration, use the ramp test pattern to verify the ADC->FPGA link is functioning correctly. If False, perform this verification with the same constant test value used for the calibration procedure.

**Returns** True if the calibration procedure succeeded. False otherwise.

Return type bool

# get\_snapshot (fmc, signed=False, trigger=True)

Read a snapshot of data from all ADC channels on a single FMC card. Return data without interleaving ADC cores.

#### **Parameters**

- fmc (int) Which FMC port (0 or 1) to read.
- **signed** (bool) If True, return data interpretted as signed 2's complement integers. If False, return data as unsigned integers.
- **trigger** (bool) If True, trigger a new simultaneous capture of data from all channels. If False, read existing data capture. Grabbing data without a new trigger may be useful if you wish to read channels from a second FMC port which were captured simultaneously with another port.

**Returns** Array of captured data with dimensions [ADC\_CHIPS\_PER\_FMC, ADC\_LANES, TIME\_SAMPLES]. Data from ADC lanes representing the same analog input are \_not\_ interleaved. Data from ADC lanes n,n+1 are associated with the same analog input.

Return type numpy.array

## get\_snapshot\_interleaved(fmc, signed=False, trigger=True)

Read a snapshot of data from all ADC channels on a single FMC card. Return data with ADC cores interleaved.

- **fmc** (*int*) Which FMC port (0 or 1) to read.
- **signed** (bool) If True, return data interpretted as signed 2's complement integers. If False, return data as unsigned integers.
- **trigger** (bool) If True, trigger a new simultaneous capture of data from all channels. If False, read existing data capture. Grabbing data without a new trigger may be useful if you wish to read channels from a second FMC port which were captured simultaneously with another port.

**Returns** numpy array of captured data with dimensions [ADC\_CHANNELS\_PER\_FMC, TIME SAMPLES].

# Return type numpy.ndarray

initialize(read only=False, clocksource=1)

Initialize connected ADC boards.

#### **Parameters**

- read\_only (bool) If True, don't do anything which would affect a running system. If False, train ADC->FPGA data links.
- **clocksource** (*int*) Which ADC board (0 or 1) on an FMC card should serve as the source of the clocks. Note that while this parameter is set for boards on all FMC cards, only the FMC card selected as the clock source at Simulink compile-time will be used for clocking.

**Returns** True if initialization was successful. False otherwise.

# mmcm\_is\_locked()

Read the ADC control register to determine if the clock PLLs are locked.

Returns True if the ADC clocks are locked. False otherwise.

# Return type bool

```
print_sweep (errs, best_delays=None, step_size=4)
```

Print, using ASCII, the valid data capture eye as a function of delay setting. Delays are printed such that one row represents a sweep of delays for a single ADC data lane. Each column in the row is X if data contained errors at this delay, – if no errors were detected at this delay, and |, if this delay is considered the best setting in the sweep range.

# **Parameters**

- **errs** (list) Array of error counts with dimensions [DELAY\_TRIALS, ADC\_CHIPS, DATA\_LANES\_PER\_ADC\_CHIP] such as that returned by \_get\_errs\_by\_delay.
- best\_delays (list) Array of best delays, with shape [ADC\_CHIPS, DATA\_LANES\_PER\_ADC\_CHIP], such as that returned by \_get\_best\_delays. These delays are marked with an ASCII |.
- **step\_size** (*int*) Number of IDELAY tap steps between delay trials.

# reset()

Toggle the ADC reset input.

# set\_delays (adc, delays)

Set IDELAY tap values for all ADC data lanes on an FMC port.

#### **Parameters**

- adc (casperfpga.ads5296.AD5296) ADS5296 object associated with an FMC ADC interface.
- **delays** (*list*) Array of delays to load, with shape [ADC\_CHIPS, DATA\_LANES\_PER\_ADC\_CHIP], such as that returned by \_get\_best\_delays.

## sync()

Toggle the ADC sync input.

# 2.2.5 Input Control

**class** lwa\_f.blocks.input.**Input** (*host*, *name*, *n\_streams=64*, *n\_bits=10*, *logger=None*) Instantiate a control interface for an Input block.

#### **Parameters**

- host (casperfpga. CasperFpga) CasperFpga interface for host.
- name (str) Name of block in Simulink hierarchy.
- logger (logging.Logger) Logger instance to which log messages should be emitted.
- n\_streams (int) Number of independent streams which may be delayed
- **n\_bits** (*int*) Number of bits per ADC sample.

# get\_all\_histograms()

Get histograms for all antpols, summing over all interleaving cores.

**Returns** (vals, hists). vals is a list of histogram bin centers. hists is an [n\_stream x 2\*\*n bits] list of histogram data.

# get\_bit\_stats()

Get the mean, RMS, and mean powers of all ADC streams.

**Returns** (means, powers, rmss) tuple. Each member of the tuple is an array with self. n\_streams elements.

**Rval** (numpy.ndarray, numpy.ndarray, numpy.ndarray)

### get\_histogram(stream, sum\_cores=True)

Get a histogram for an ADC stream.

# **Parameters**

- **stream** (*int*) ADC stream from which to get data.
- **sum\_cores** (bool) If True, compute one histogram from both A & B ADC cores. If False, compute separate histograms.

**Returns** If sum\_cores is True, return (vals, hist), where vals is a list of histogram bin centers, and hist is a list of histogram data points. If sum\_cores is False, return (vals, hist\_a, hist\_b), where hist\_a and hist\_b are separate histogram data sets for the A and B ADC cores, respectively.

# get\_status()

Get status and error flag dictionaries.

Status keys:

- switch\_position<n> (str): Switch position ('noise', 'adc' or 'zero') for input stream n, where n is a two-digit integer starting at 00. Any input position other than 'adc' is flagged with "NOTIFY".
- power<n> (float): Mean power of input stream n, where n is a two-digit integer starting at 00. In units of (ADC LSBs)\*\*2.
- rms<n> (float): RMS of input stream n, where n is a two-digit integer starting at 00. In units of ADC LSBs. Value is flagged as a warning if it is >30 or <5.
- mean<n> (float): Mean sample value of input stream n, where n is a two-digit integer starting at 00. In units of ADC LSBs. Value is flagged as a warning if it is > 2.

**Returns** (status\_dict, flags\_dict) tuple. *status\_dict* is a dictionary of status key-value pairs. flags\_dict is a dictionary with all, or a sub-set, of the keys in *status\_dict*. The values held in this dictionary are as defined in *error\_levels.py* and indicate that values in the status dictionary are outside normal ranges.

# get\_switch\_positions()

Get the positions of the input switches.

**Returns** List of switch positions. Entry n contains the position of the switch associated with ADC input n. Switch positions are "noise" (internal digital noise generators), "adc" (digitized ADC stream), or "zero" (constant 0).

**Return type** list of str

```
initialize(read_only=False)
```

Initialize the block.

**Parameters read\_only** (bool) – If True, do nothing. If False, set the input multiplexers to ADC data and enable statistic computation.

```
plot histogram(stream)
```

Plot a histogram.

Parameters stream (int) - ADC stream from which to get data.

# print\_histograms()

Print histogram stats to screen.

```
use adc(stream=None)
```

Switch input to ADC.

Parameters stream (int or None) - Which stream to switch. If None, switch all.

```
use_noise (stream=None)
```

Switch input to internal noise source.

Parameters stream (int or None) - Which stream to switch. If None, switch all.

```
use_zero (stream=None)
```

Switch input to zeros.

Parameters stream (int or None) - Which stream to switch. If None, switch all.

# 2.2.6 Noise Generator Control

```
class lwa_f.blocks.noisegen.NoiseGen (host, name, n_noise=5, n_outputs=64, logger=None)

Noise Generator controller
```

This block controls a digital noise source, which can generate multiple independent channels of gaussian noise. These channels can be assigned to multiple outputs of this block, to create correlated or uncorrelated noise streams.

- host (casperfpga.CasperFpga) CasperFpga interface for host.
- name (str) Name of block in Simulink hierarchy.
- logger (logging.Logger) Logger instance to which log messages should be emitted.
- n\_noise (int) The number of independent noise generation cores in the underlying block. 2\*n\_noise independent noise streams will be produced.

• **n\_outputs** (*int*) – The number of output channels from the block.

### assign\_output (output, noise)

Assign an output channel to a given noise stream. Note that the output stream will not be affected unless the downstream input multiplexors are set to noise mode.

## **Parameters**

- **output** (*int*) The index of the output stream to be assigned.
- **noise** (*int*) The index of the noise stream to assign to *output*. Note that each noise generator core generates two independent streams, so *noise* can be in range(0, 2\*self.n\_noise)

# get\_output\_assignment(output)

Get the index of the noise stream assigned to an output.

**Parameters** output (int) – The index of the output stream to query.

**Returns** The index of the noise stream to assign to *output*. Note that each noise generator core generates two independent streams, so *noise* can be in range(0, 2\*self.n\_noise)

Return type int

# $get\_seed(n)$

Get the seed of a noise generator.

**Parameters** n (int) – Noise generator ID whose seed to read.

Returns Noise generator seed.

Rtype int

# get\_status()

Get status and error flag dictionaries.

Status keys:

- noise\_core<m>\_seed (int): Seed currently loaded into noise generator core m. m should be a two-digit integer starting at 00.
- output\_assignment<n> (int): The noise generator ID currently assigned to output stream n, where n is a two-digit integer starting at 00.

**Returns** (status\_dict, flags\_dict) tuple. *status\_dict* is a dictionary of status key-value pairs. flags\_dict is a dictionary with all, or a sub-set, of the keys in *status\_dict*. The values held in this dictionary are as defined in *error\_levels.py* and indicate that values in the status dictionary are outside normal ranges.

#### initialize (read\_only=False)

Initialize the block

**Parameters** read\_only (bool) – If False, set the seen of noise generator n to n. If True, do nothing.

# $\mathtt{set\_seed}(n, seed)$

Set the seed of a noise generator.

- n (int) Noise generator ID to seed.
- **seed** (*int*) Noise generator seed to load.

# 2.2.7 Delay Control

**class** lwa\_f.blocks.delay.**Delay** (*host*, *name*, *n\_streams=64*, *logger=None*) Instantiate a control interface for a Delay block.

#### **Parameters**

- host (casperfpga. CasperFpga) CasperFpga interface for host.
- name (str) Name of block in Simulink hierarchy.
- logger (logging.Logger) Logger instance to which log messages should be emitted.
- n\_streams (int) Number of independent streams which may be delayed

#### MIN DELAY = 5

minimum delay allowed

# get\_delay (stream)

Get the current delay for a given input.

Parameters stream (int) - Which ADC input index to query

Returns Currently loaded delay, in ADC samples

Return type int

#### get max delay()

Query the firmware to get the maximum delay it supports.

Returns Maximum supported delay, in ADC samples

Return type int

# get\_status()

Get status and error flag dictionaries.

Status keys:

- delay<n>: Currently loaded delay for ADC input index n. in units of ADC samples.
- max delay: The maximum delay supported by the firmware.
- min\_delay: The minimum delay supported by the firmware.

**Returns** (status\_dict, flags\_dict) tuple. *status\_dict* is a dictionary of status key-value pairs. flags\_dict is a dictionary with all, or a sub-set, of the keys in *status\_dict*. The values held in this dictionary are as defined in *error\_levels.py* and indicate that values in the status dictionary are outside normal ranges.

# initialize(read\_only=False)

Initialize all delays.

**Parameters read\_only** (bool) – If True, do nothing. If False, initialize all delays to the minimum allowed value.

#### set delay (stream, delay)

Set the delay for a given input stream.

- **stream** (*int*) ADC stream index to which delay should be applied.
- **delay** (*int*) Number of ADC clock cycles delay to load.

# 2.2.8 PFB Control

class lwa\_f.blocks.pfb.Pfb (host, name, logger=None)

#### get\_status()

Get a dictionary of status values, with optional warning of error flags. To be overridden by individual blocks

**Returns** (status\_dict, flags\_dict) tuple. *status\_dict* is a dictionary of status key-value pairs, defined on a per-block basis. flags\_dict is a dictionary with all, or a sub-set, of the keys in *status\_dict*. The values held in this dictionary should be as defined in *error\_levels.py*.

```
initialize(read only=False)
```

Individual blocks should override this method to configure themselves appropriately

**Parameters read\_only** (bool) – If False, initialize blocks in a way that might change the configuration of running hardware. If True, read runtime info from blocks, but don't change anything.

# 2.2.9 Auto-correlation Control

Instantiate a control interface for an Auto-Correlation block.

#### **Parameters**

- host (casperfpga.CasperFpga) CasperFpga interface for host.
- name (str) Name of block in Simulink hierarchy.
- logger (logging.Logger) Logger instance to which log messages should be emitted.
- acc\_len (int) Accumulation length initialization value, in spectra.
- **n\_chans** (*int*) Number of frequency channels.
- n pols (int) Number of individual data streams.
- n\_parallel\_streams (int) Number of streams processed by the firmware module in parallel.
- **n\_cores** (*int*) Number of accumulation cores in firmware design.
- use\_mux (bool) If True, only one core is instantiated and a multiplexer is used to switch different inputs into it. If False, multiple cores are instantiated simultaneously in firmware.

```
get_acc_len()
```

Get the currently loaded accumulation length in units of spectra.

**Returns** Current accumulation length

Return type int

```
get_new_spectra(core=0)
```

Get a new average power spectra.

**Parameters** core (*int*) – If using multiplexing, read data for this core. If not using multiplexing, read data from all cores.

**Returns** Float32 array of dimensions [POLARIZATION, FREQUENCY CHANNEL] containing autocorrelations with accumulation length divided out.

Return type numpy.array

#### get status()

Get status and error flag dictionaries.

Status keys:

• acc\_len (int): Currently loaded accumulation length in number of spectra.

**Returns** (status\_dict, flags\_dict) tuple. *status\_dict* is a dictionary of status key-value pairs. flags\_dict is a dictionary with all, or a sub-set, of the keys in *status\_dict*. The values held in this dictionary are as defined in *error\_levels.py* and indicate that values in the status dictionary are outside normal ranges.

# initialize (read\_only=False)

Initialize the block, setting (or reading) the accumulation length.

**Parameters read\_only** (bool) – If False, set the accumulation length to the value provided when this block was instantiated. If True, use whatever accumulation length is currently loaded.

# plot\_spectra (core=0, db=True, show=True)

Plot the spectra of all polarizations in a single core, with accumulation length divided out

#### **Parameters**

- core (int) If using multiplexing, read data for this core. If not using multiplexing, read data from all cores.
- **db** (bool) If True, plot 10log10(power). Else, plot linear.
- **show** (bool) If True, call matplotlib's *show* after plotting

Returns matplotlib. Figure

```
set_acc_len (acc_len)
```

Set the number of spectra to accumulate.

Parameters acc\_len (int) - Number of spectra to accumulate

# 2.2.10 Correlation Control

**class** lwa\_f.blocks.corr.**Corr** (*host*, *name*, *acc\_len=1024*, *logger=None*, *n\_chans=1024*) Instantiate a control interface for a Correlation block.

## **Parameters**

- host (casperfpga. CasperFpga) CasperFpga interface for host.
- name (str) Name of block in Simulink hierarchy.
- **logger** (*logging.Logger*) Logger instance to which log messages should be emitted.
- acc\_len (int) Accumulation length initialization value, in spectra.
- n\_chans (int) Number of frequency channels in the correlation output.

### get\_acc\_len()

Get the currently loaded accumulation length in units of spectra.

**Returns** Current accumulation length

Return type int

```
get_new_corr (pol1, pol2, flush_vacc=True)
```

Get a new correlation.

### **Parameters**

- **pol1** (*int*) First (unconjugated) polarization index.
- **pol2** (*int*) Second (conjugated) polarization index.
- **flush\_vacc** (bool) If True, throw away the first accumulation after setting the input selection registers. This is good practice the first time a new polarization pair is read.

**Returns** Complex-valued cross-correlation spectra of *pol1* and *pol2* with accumulation length divided out.

Return type numpy.array

#### get\_status()

Get status and error flag dictionaries.

Status keys:

• acc\_len: Currently loaded accumulation length in number of spectra.

**Returns** (status\_dict, flags\_dict) tuple. *status\_dict* is a dictionary of status key-value pairs. flags\_dict is a dictionary with all, or a sub-set, of the keys in *status\_dict*. The values held in this dictionary are as defined in *error\_levels.py* and indicate that values in the status dictionary are outside normal ranges.

```
initialize(read_only=False)
```

Initialize the block, setting (or reading) the accumulation length.

**Parameters read\_only** (bool) – If False, set the accumulation length to the value provided when this block was instantiated. If True, use whatever accumulation length is currently loaded.

```
plot_corr (pol1, pol2, show=False)
```

Plot a correlation spectra.

## **Parameters**

- **pol1** (*int*) First (unconjugated) polarization index.
- pol2 (int) Second (conjugated) polarization index.
- **show** (bool) If True, call matplotlib's *show* after plotting

Returns matplotlib. Figure

```
set_acc_len (acc_len)
```

Set the number of spectra to accumulate.

Parameters acc\_len (int) - Number of spectra to accumulate

# 2.2.11 Post-FFT Test Vector Control

**class** lwa\_f.blocks.eqtvg.**EqTvg** (*host*, *name*, *n\_streams=64*, *n\_chans=4096*, *logger=None*) Instantiate a control interface for a post-equalization test vector generator block.

#### **Parameters**

- host (casperfpga. CasperFpga) CasperFpga interface for host.
- name (str) Name of block in Simulink hierarchy.
- logger (logging.Logger) Logger instance to which log messages should be emitted.
- n\_streams (int) Number of independent streams which may be delayed
- **n\_chans** (*int*) Number of frequency channels.

# get\_status()

Get status and error flag dictionaries.

Status keys:

• tvg\_enabled: Currently state of test vector generator. True if the generator is enabled, else False.

**Returns** (status\_dict, flags\_dict) tuple. *status\_dict* is a dictionary of status key-value pairs. flags\_dict is a dictionary with all, or a sub-set, of the keys in *status\_dict*. The values held in this dictionary are as defined in *error\_levels.py* and indicate that values in the status dictionary are outside normal ranges.

# initialize (read\_only=False)

Initialize the block.

**Parameters read\_only** (bool) – If True, do nothing. If False, load frequency-ramp test vectors, but disable the test vector generator.

# read\_stream\_tvg(stream)

Read the test vector loaded to an ADC stream.

Parameters stream (int) - Index of stream from which test vectors should be read.

**Returns** Test vector array, as loaded to the FPGA in 8-bit unsigned integer representation.

Return type numpy.ndarray

# tvg\_disable()

Disable the test vector generator

#### tvg enable()

Enable the test vector generator.

# tvg\_is\_enabled()

Query the current test vector generator state.

**Returns** True if the test vector generator is enabled, else False.

Return type bool

# write\_const\_per\_stream()

Write a constant to all the channels of a stream, with stream i taking the value i.

# write\_freq\_ramp()

Write a frequency ramp to the test vector that is repeated for all ADC inputs. Data are wrapped to fit into 8 bits. I.e., the test vector value for channel 257 takes the value 1.

### write\_stream\_tvg(stream, test\_vector)

Write a test vector pattern to a single signal stream.

#### **Parameters**

- **stream** (*int*) Index of stream to which test vectors should be loaded.
- **test\_vector** (list or numpy.ndarray) self:n\_chans-element test vector. Values should be representable in 8-bit unsigned integer format. Data are loaded such that the most-significant 4 bits of the test\_vectors are interpretted as the 2's complement 4-bit real sample data. The least-significant 4 bits of the test vectors are interpretted as the 2's complement 4-bit imaginary sample data.

# 2.2.12 Equalization Control

**class** lwa\_f.blocks.eq.**Eq** (host, name, n\_streams=64, n\_coeffs=512, logger=None) Instantiate a control interface for an Equalization block.

### **Parameters**

- host (casperfpga. CasperFpga) CasperFpga interface for host.
- name (str) Name of block in Simulink hierarchy.
- logger (logging.Logger) Logger instance to which log messages should be emitted.
- n\_streams (int) Number of independent streams which may be delayed
- n\_coeffs (int) Number of coefficients per input stream. Coefficients are shared among neighbouring frequency channels.

## clip\_count()

Get the total number of times any samples have clipped, since last sync.

Returns Clip count.

Return type int

# get coeffs(stream)

Get the coefficients currently loaded. Reads the actual coefficients from the board.

**Parameters** stream (int) – ADC stream index to query.

**Returns** (coeffs, binary\_point). coeffs is an array of self.n\_coeffs integer coefficients currently being applied. binary\_point is the position of the binary point wy which these integers are scaled on the FPGA.

Return type (numpy.ndarray, int)

## get\_status()

Get status and error flag dictionaries.

Status keys:

- clip\_count: Number of clip events in the last sync period.
- width: Bit width of coefficients
- binary\_point: Binary point position of coefficients
- coefficients<n>: The currently loaded, integer-valued coefficients for ADC stream n.

**Returns** (status\_dict, flags\_dict) tuple. *status\_dict* is a dictionary of status key-value pairs. flags\_dict is a dictionary with all, or a sub-set, of the keys in *status\_dict*. The values held in this dictionary are as defined in *error\_levels.py* and indicate that values in the status dictionary are outside normal ranges.

# initialize (read\_only=False)

Initialize block.

**Parameters read\_only** (bool) – If False, set all coefficients to some nominally sane value. Currently, this is 100.0. If True, do nothing.

### set\_coeffs (stream, coeffs)

Set the coefficients for a data stream. Clipping and saturation will be applied before loading.

#### **Parameters**

- **stream** (*int*) ADC stream index to which coefficients should be applied.
- **coeffs** (*list or numpy.ndarray*) Array of coefficients to load. This should be of length self.n\_coeffs, else an AssertionError will be raised.

# 2.2.13 Channel Selection Control

class lwa\_f.blocks.chanreorder.ChanReorder (host, name, n\_chans=1024, logger=None)
Instantiate a control interface for a Channel Reorder block.

# **Parameters**

- host (casperfpga.CasperFpga) CasperFpga interface for host.
- name (str) Name of block in Simulink hierarchy.
- logger (logging.Logger) Logger instance to which log messages should be emitted.
- **n\_chans** (*int*) Number of channels in the system.

# initialize(read\_only=False)

Initialize the block.

**Parameters** read\_only (bool) – If True, this method is a no-op. If False, initialize the block with the identity map. I.e., map channel n to channel n.

# n\_parallel\_chans = 8

Number of channels per reorder word

# read reorder(raw=False)

Read the currently loaded reorder map.

**Parameters** raw(bool) – If True, return the map as loaded onto the FPGA. If False, return the resulting channel map – i.e., the channel ordering being output by this F-engine.

**Returns** The reorder map currently loaded.

Return type list

# set channel order(order)

Re-order channels so that they are sent with the order in the specified map.

There are various requirements of the map which must be met.

• Every integer multiple of *self.n\_parallel\_chans* of the map must start on an integer multiple of *n\_parallel\_chans*. Eg., for *n\_parallel\_chans* = 8 order[0] = 16 is acceptable. order[0] = 4 is not.

- Blocks of  $n_parallel_channels$  must be consecutive. Eg., if  $n_parallel_chans=8$ , order[16:24] = [0,1,2,3,4,5,6,7] is acceptable. order[16:24] = [0,1,2,3,8,9,10,11] is not.
- The provided map must be *self.n\_chans* elements long.

**Parameters order** (list of int) – The order to which data should be mapped. I.e., if order[0] = 16, then the first channel out of the F-engine will be channel 16. The order map should meet the above criteria. A ValueError exception will be raised if they are not.

# 2.2.14 Packetization Control

The packetizer block allows dynamic definition of packet sizes and contents. In firmware, it is a simple block which allows insertion of header entries and EOFs at any point in the incoming data stream. It is up to the user to configure this block such that it behaves in a reasonable manner – i.e.

- Output data rate does not overflow the downstream Ethernet core
- · Packets have a reasonable size
- EOFs and headers are correctly placed.

#### **Parameters**

- host (casperfpga. CasperFpga) CasperFpga interface for host.
- name (str) Name of block in Simulink hierarchy.
- logger (logging.Logger) Logger instance to which log messages should be emitted.
- n\_chans (int) Number of frequency channels in the correlation output.
- n\_pols (int) Number of independent analog streams in the system
- sample\_rate\_mhz (float) ADC sample rate in MHz. Used for data rate checks.

get\_packet\_info (n\_pkt\_chans, occupation=0.95, chan\_block\_size=8)

Get the packet boundaries for packets containing a given number of frequency channels.

## **Parameters**

- n\_pkt\_chans (int) The number of channels per packet.
- **occupation** (float) The maximum allowed throughput capacity of the underlying link. The calculation does not include application or protocol overhead, so must necessarily be < 1.
- **chan\_block\_size** (*int*) The granularity with which we can start packets. I.e., packets must start on an n\*`chan\_block` boundary.

# Returns

packet\_starts, packet\_payloads, channel\_indices

**packet\_starts** [list of ints] The word indexes where packets start – i.e., where headers should be written. For example, a value [0, 1024, 2048, ...] indicates that headers should be written into underlying brams at addresses 0, 1024, etc.

- **packet\_payloads** [list of range()] The range of indices where this packet's payload falls. Eg: [range(1,257), range(1025,1281), range(2049,2305), ... etc] These indices should be marked valid, and the last given an EOF.
- **channel\_indices** [list of range()] The range of channel indices this packet will send. Eg: [range(1,129), range(1025,1153), range(2049,2177), ... etc] Channels to be sent should be re-indexed so that they fall into these ranges.

Write the packetizer configuration BRAMs with appropriate entries.

## **Parameters**

- **packet\_starts** (list of int) Word-indices which are the first entry of a packet and should be populated with headers (see get\_packet\_info())
- packet\_payloads (list of range()s) Word-indices which are data payloads, and should be mared as valid (see get\_packet\_info())
- **channel\_indices** (list of ints) Header entries for the channel field of each packet to be sent
- ant\_indices (list of ints) Header entries for the antenna field of each packet to be sent
- **dest\_ips** list of str IP addresses for each packet to be sent.
- **dest\_ports** (list of int) UDP destination ports for each packet to be sent.
- print (bool) If True, print config for debugging

All parameters should have identical lengths.

# 2.2.15 Ethernet Output Control

**class** lwa\_f.blocks.eth.**Eth** (*host*, *name*, *logger=None*)
Instantiate a control interface for a 40 GbE block.

# **Parameters**

- host (casperfpga. CasperFpga) CasperFpga interface for host.
- name (str) Name of block in Simulink hierarchy.
- logger (logging.Logger) Logger instance to which log messages should be emitted.

# add\_arp\_entry(ip, mac)

Set a single arp entry.

#### **Parameters**

- ip (int) The last octet of the IP address matching the given MAC.
- mac (int) The MAC address to be loaded to the ARP cache.

# disable\_tx()

Disable Ethernet transmission.

# enable\_tx()

Enable Ethernet transmission.

#### get status()

Get a dictionary of status values, with optional warning of error flags. To be overridden by individual blocks

**Returns** (status\_dict, flags\_dict) tuple. *status\_dict* is a dictionary of status key-value pairs, defined on a per-block basis. flags\_dict is a dictionary with all, or a sub-set, of the keys in *status\_dict*. The values held in this dictionary should be as defined in *error\_levels.py*.

## initialize(read only=False)

Individual blocks should override this method to configure themselves appropriately

**Parameters read\_only** (bool) – If False, initialize blocks in a way that might change the configuration of running hardware. If True, read runtime info from blocks, but don't change anything.

#### reset()

Disable, then reset the 40 GbE core. It must be enabled with enable\_tx before traffic will be transmitted.

# set\_arp\_table (macs)

Set the ARP table with a list of MAC addresses.

**Parameters macs** (list of int) – MAC addresses to be loaded into the ARP table. These should be the form of a list of integers, such that the "n"th list entry contains the MAC address of the device with IP XXX.XXX.XXX.n.

### status reset()

Reset all status counters.

# 2.3 etcd Interface

The etcd F-Engine interface provides a mechanism to control multiple SNAP2 boards running F-Engine firmware via the passing of messages through an etcd key-value store.

In order to use the etcd control interface, a daemon Snap2FengineEtcdClient instance is required to be running on a server with network access to the SNAP2 hardware being controlled.

# 2.3.1 Key Organization

For an F-Engine running on a SNAP2 hostname, there are three relevant etcd key paths.

# Command

The command key is:

/cmd/snap/<hostname>/command

Writing messages to this key results in the execution of Snap2Fengine command methods.

# Response

Each command written to the command key will elicit a response published to the key:

```
/resp/snap/<hostname>/response
```

The response message will indicate the success of failure of the command, and may contain a command-dependent data payload. For example, a spectra, or snapshot of ADC samples.

### **Monitor**

In addition to the Command/Response control protocol, general telemetry relating to pipeline element blockname can be read from the keys beneath the path:

```
/mon/snap/<hostname>/<blockname>
```

Such keys are indended to be continuously updated on a ~1 second time cadence, and contain low data-volume status information. For example, FPGA temperature, ADC RMS, number of transmitted Ethernet packets, and similar.

# 2.3.2 Command/Response Protocol

The Command/Response protocol is designed to be a simple interface to the underlying Snap2Fengine control class. It will naturally extend as the control class functionality is expanded.

A simple example of a control client is implemented in the Snap2FengineEtcdControl class, which is used for internal testing.

# **Command Format**

Commands sent to the command key are JSON-encoded dictionaries, and should have the following fields:

| Field     | Туре    | Description                                                                       |
|-----------|---------|-----------------------------------------------------------------------------------|
| se-       | integer | A unique integer associated with this command, used to identify the command's re- |
| quence_id |         | sponse                                                                            |
| timestamp | float   | The UNIX time when this command was issued                                        |
| command   | string  | Command Name                                                                      |
| block     | string  | Firmware block name to which command applies                                      |
| kwargs    | dictio- | Dictionary of arguments required by the block.command method                      |
|           | nary    |                                                                                   |

Allowed values for "block" are any of the keys in the Snap2Fengine blocks attribute. I.e.:

```
from lwa_f import snap2_fengine
f = snap2_fengine.Snap2Fengine('snap2-rev2-11')
for block in sorted(f.blocks.keys()): print(block)
adc
autocorr
corr
delay
eq
eq_tvg
eth
input
noise
```

(continues on next page)

2.3. etcd Interface 25

(continued from previous page)

```
packetizer
pfb
reorder
sync
```

Allowed values for `command` are any of the methods which can be called against Snap2Fengine. blocks[block]. For example, for the delay block, allowed commands are:

- get\_max\_delay
- set\_delay
- get\_delay
- initialize
- get status

All blocks are instances of the generic Block class, and thus it is also possible to call parent class methods such as read\_uint and write\_uint. These directly manipulate FPGA registers, and should be used with caution.

The "kwargs" field should contain any arguments required by the command method being called. For example, the Fengine delay block's set\_delay method requires a stream argument (to select which of the 64 SNAP2 data streams is being manipulated) and a delay argument (to set the delay for this stream).

As such, in order to set the delay of data stream 5 to 100 adc samples, a command should be issued with:

| Field   | Value                       |
|---------|-----------------------------|
| block   | "delay"                     |
| command | "set_delay"                 |
| kwargs  | {"stream": 5, "delay": 100} |

An example of a valid command JSON string, issued with the above parameters at UNIX time 1618060712.60 and with sequence\_id=1 is:

```
'{"block": "delay", "timestamp": 1618060712.6, "kwargs": {"delay": 100, "stream": 5}, "command": "set_delay", "sequence_id": 1}'
```

Consult the Snap2Fengine API details for a list of commands and their arguments.

# **Response Format**

Every command sent elicits the writing of JSON-encoded dictionary to the response key. This dictionary has the following fields:

| Field  | Type       | Description                                                                                       |
|--------|------------|---------------------------------------------------------------------------------------------------|
| se-    | integer    | An integer matching the sequence_id field of the command string to which this is a response       |
| quenc  | e_id       |                                                                                                   |
| times- | - float    | The UNIX time when this response was issued                                                       |
| tamp   |            |                                                                                                   |
| sta-   | string     | The string "normal" if the corresponding command was processed without error, or "error" if it    |
| tus    |            | was not.                                                                                          |
| re-    | comman     | d-The response of the command method, as determined by the command API. If a method would         |
| spons  | e depender | ntusually return a numpy array, when using the etcd interface the response will be a list. In the |
|        |            | event that the status field is "error", The response field will contain an error message string   |

Not all Snap2Fengine methods return values, in whice case the response field is null. The previous command example (setting a delay) results in the underlying API call Snap2Fengine.blocks['delay'].set\_delay(5, 100) which returns None. The response to the example command (assuming processing the command took 0.2 milliseconds) is thus:

| Field       | Value        |
|-------------|--------------|
| sequence_id | 1            |
| timestamp   | 1618060712.8 |
| status      | "normal"     |
| response    | null         |

# or, in JSON-encoded form:

```
'{"sequence_id": 1, "timestamp": 1618060712.8, "status": "normal", "response": null}'
```

If the response status field is "error", common response error messages, and their meanings are:

| "JSON decode er-<br>ror" | Command string could not be JSON-decoded.                                             |
|--------------------------|---------------------------------------------------------------------------------------|
| "Sequence ID not in-     | Sequence ID was not provided in the command string or decoded to a non-integer value. |
| teger"                   |                                                                                       |
| "Bad command for-        | Received command did not comply with formatting specifications. E.g. was missing a    |
| mat"                     | required field such as block or command.                                              |
| "Command invalid"        | Received command doesn't exist in the Snap2Fengine API, or is prohibited for etcd     |
|                          | access.                                                                               |
| "Wrong block"            | block field of the command decoded to a block which doesn't exist.                    |
| "Command argu-           | kwargs key contained missing, or unexpected keys.                                     |
| ments invalid"           |                                                                                       |
| "Command failed"         | The underlying Snap2Fengine API call raised an exception.                             |

In the event that a command fails, more information is available in the Snap2FengineEtcdClient daemon logs.

# **Monitoring Interface**

| autocorr/acc_len        | int        | Accumulation length, in spectra, of the internal autocorrelation module.                           |  |
|-------------------------|------------|----------------------------------------------------------------------------------------------------|--|
| corr/acc_len            | int        | Accumulation length, in spectra, of the internal correlation module.                               |  |
| delay/n/delay           | int        | Delay of each of the n data streams.                                                               |  |
| delay/maxdelay          | int        | The maximum delay supported by the firmware.                                                       |  |
| eq/binary_point         | int        | The position of the EQ coefficient binary point                                                    |  |
| eq/width                | int        | The bit width of the EQ coefficients                                                               |  |
| eq/clip_count           | int        | The number of clips when requantizing spectra to 4-bit. This counter resets every [TODO: w         |  |
| eq/n/coefficients       | list (int) | The currently loaded coefficients, in integer form (i.e., interpretted with all bits above the bin |  |
| eq_tvg/tvg_enabled      | bool       | True if the post-FFT test vector generator is enabled. False otherwise.                            |  |
| eth/tx_ctr              | int        | Running count of number of packets transmitted.                                                    |  |
| eth/tx_err              | int        | Running count of number of packet errors detected.                                                 |  |
| eth/tx_full             | int        | Running count of number of transmission buffer overflow events.                                    |  |
| eth/tx_vld              | int        | Running count of number of 256-bit words transmitted.                                              |  |
| feng/flash_firmware     | string     | The current .fpg bitstream file stored in flash memory                                             |  |
| feng/flash_firmware_md5 | int        | The MD5 checksum of the .fpg bitstream stored in flash                                             |  |

2.3. etcd Interface 27

Table 2.1 – continued from previous pa

| autocorr/acc_len          | int    | Accumulation length, in spectra, of the internal autocorrelation module.                     |
|---------------------------|--------|----------------------------------------------------------------------------------------------|
| feng/host                 | string | The hostname of the SNAP2 board                                                              |
| feng/programmed           | bool   | True if the board appears to be running DSP firmware. False otherwise.                       |
| feng/fw_version           | string | The version string of the currently running firmware, presented as major_v ersion.mir        |
| feng/fw_build_time        | int    | The time, in seconds since 00:00:00 on 1 January 1970, that the currently running firmware v |
| feng/serial               | string | A notional "serial number" of this hardware. Not yet implemented.                            |
| feng/sw_version           | string | The software version of the lwa_f python library currently in use                            |
| feng/sys_mon              | string | "reporting" if the current firmware has a working system monitor module. "not reporting" if  |
| feng/temp                 | float  | FPGA junction temperature, in degrees C, reported by system monitor (if available)           |
| feng/vccaux               | float  | Voltage of the VCCAUX FPGA power rail reported by system monitor (if available)              |
| feng/vccbram              | float  | Voltage of the VCCBRAM FPGA power rail reported by system monitor (if available)             |
| feng/vccint               | float  | Voltage of the VCCINT FPGA power rail reported by system monitor (if available)              |
| input/n/mean              | float  | Mean of ADC sample values for input ADC n.                                                   |
| input/n/rms               | float  | RMS of ADC sample values for input ADC n.                                                    |
| input/n/power             | float  | Mean of squares of ADC sample values for input ADC n.                                        |
| input/n/switch_position   | string | Switch position for input data stream n. noise for internal noise generators, add for analog |
| noise/noise_core00_seed   | int    | Seed value for internal noise generator 0.                                                   |
| noise/noise_core01_seed   | int    | Seed value for internal noise generator 1.                                                   |
| noise/noise_core02_seed   | int    | Seed value for internal noise generator 2.                                                   |
| noise/n/output_assignment | int    | Noise source (0 - 5) currently assigned to data stream n.                                    |
| pfb/fft_shift             | int    | Currently loaded FFT shift schedule.                                                         |
| pfb/overflow_count        | int    | Running count of FFT overflow events.                                                        |
| sync/ext_count            | int    | Running count of number of external sync pulses received since FPGA was programmed.          |
| sync/int_count            | int    | Running count of number of internal sync pulses received since FPGA was programmed.          |
| sync/period_fpga_clks     | int    | Detected period of external sync pulses in units of FPGA clock cycles.                       |
| sync/uptime_secs          | int    | Number of seconds since FPGA was last programmed                                             |
|                           |        |                                                                                              |

# F-ENGINE REGISTER DEFINITIONS

F-Engine firmware is designed to be manipulated using the provided Snap2FEngine class, or its higher level etcd-based control interface.

However, individual F-engine registers and their purposes are described below.

# 3.1 Register Descriptions

| Register Name                          | Size    | Permis- | Description                                          |
|----------------------------------------|---------|---------|------------------------------------------------------|
|                                        | (Bytes) | sion    |                                                      |
| ADC Registers                          |         |         |                                                      |
| ads5296_controller_ <i>_<j></j></i>    | 128     | r/w     | ADS5296 board control register for the j th ADC      |
|                                        |         |         | card in FMC i. Should be manipulated using the       |
|                                        |         |         | ADS5296 class of the casperfpga python li-           |
|                                        |         |         | brary.                                               |
| ads5296_spi_controller <i></i>         | 16      | r/w     | ADS5296 SPI controller register for ADC cards        |
|                                        |         |         | on FMC slot i. Should be manipulated using the       |
|                                        |         |         | ADS5296 class of the casperfpga python li-           |
|                                        |         |         | brary.                                               |
| ads5296_wb_ram <i>_<j>_<k></k></j></i> | 4096    | r/w     | ADC snapshot RAM for ADC chip k on board j           |
|                                        |         |         | of FMC port i. Should be manipulated using the       |
|                                        |         |         | ADS5296 class of the casperfpga python li-           |
|                                        |         |         | brary.                                               |
| adc_rst                                | 4       | r/w     | Set to 1 to assert the ADC reset. This flushes the   |
|                                        |         |         | ADC output FIFOs. Data will not begin flowing        |
|                                        |         |         | again until the ADC sync input transitions from 0    |
|                                        |         |         | to 1.                                                |
| adc_snapshot_trigger                   | 4       | r/w     | When this register transitions from 0 to 1, all ADC  |
|                                        |         |         | channels will simultaneously capture a burst of ADC  |
|                                        |         |         | samples.                                             |
| adc_sync                               | 4       | r/w     | Write 1 to this register to assert the ADC's sync    |
|                                        |         |         | input. This input is edge sensitive.                 |
| Auto-Correlator Registers              |         |         |                                                      |
| autocorr_acc_cnt                       | 4       | r       | 32-bit wrapping accumulation counter, which incre-   |
|                                        |         |         | ments each time a new accumulation is recorded to    |
|                                        |         |         | RAM. There is no buffer locking when correlation     |
|                                        |         |         | data are read, so this counter can be used to ensure |
|                                        |         |         | that data have not changed during a read.            |
| autocorr_acc_len                       | 4       | r/w     | Accumulation length, in spectra.                     |

Table 3.1 – continued from previous page

| Pagistar Nama                         |         | Permis-  | Description                                                |
|---------------------------------------|---------|----------|------------------------------------------------------------|
| Register Name                         | Size    |          | Description                                                |
|                                       | (Bytes) | sion     |                                                            |
| auto-                                 | 262144  | r/w      | For memory name suffix <n>_bram, stores the au-</n>        |
| corr_common_dout0_bram                |         |          | tocorrelation powers for frequency channels 8n of          |
|                                       |         |          | 16 consective F-engine inputs. Data are stored in          |
|                                       |         |          | [input_number, freq_channel] order.                        |
| auto-                                 | 262144  | r/w      | For memory name suffix <n>_bram, stores the au-</n>        |
| corr_common_dout1_bram                |         |          | tocorrelation powers for frequency channels 8n of          |
| • • • • • • • • • • • • • • • • • • • |         |          | 16 consective F-engine inputs. Data are stored in          |
|                                       |         |          | [input_number, freq_channel] order.                        |
| auto-                                 | 262144  | r/w      | For memory name suffix <n>_bram, stores the au-</n>        |
|                                       | 202144  | 17 W     |                                                            |
| corr_common_dout2_bram                |         |          | tocorrelation powers for frequency channels 8n of          |
|                                       |         |          | 16 consective F-engine inputs. Data are stored in          |
|                                       |         |          | [input_number, freq_channel] order.                        |
| auto-                                 | 262144  | r/w      | For memory name suffix <n>_bram, stores the au-</n>        |
| corr_common_dout3_bram                |         |          | tocorrelation powers for frequency channels 8n of          |
|                                       |         |          | 16 consective F-engine inputs. Data are stored in          |
|                                       |         |          | [input_number, freq_channel] order.                        |
| auto-                                 | 262144  | r/w      | For memory name suffix <n>_bram, stores the au-</n>        |
| corr_common_dout4_bram                |         |          | tocorrelation powers for frequency channels 8n of          |
|                                       |         |          | 16 consective F-engine inputs. Data are stored in          |
|                                       |         |          | [input_number, freq_channel] order.                        |
| auto-                                 | 262144  | r/w      | For memory name suffix <n>_bram, stores the au-</n>        |
| corr_common_dout5_bram                | 202144  | 17 W     | tocorrelation powers for frequency channels 8n of          |
| corr_common_douts_brain               |         |          |                                                            |
|                                       |         |          | 16 consective F-engine inputs. Data are stored in          |
|                                       |         | <u> </u> | [input_number, freq_channel] order.                        |
| auto-                                 | 262144  | r/w      | For memory name suffix <n>_bram, stores the au-</n>        |
| corr_common_dout6_bram                |         |          | tocorrelation powers for frequency channels 8n of          |
|                                       |         |          | 16 consective F-engine inputs. Data are stored in          |
|                                       |         |          | [input_number, freq_channel] order.                        |
| auto-                                 | 262144  | r/w      | For memory name suffix <n>_bram, stores the au-</n>        |
| corr_common_dout7_bram                |         |          | tocorrelation powers for frequency channels 8n of          |
|                                       |         |          | 16 consective F-engine inputs. Data are stored in          |
|                                       |         |          | [input_number, freq_channel] order.                        |
| autocorr_mux_sel                      | 4       | r/w      | Input selection controller. Set bits [1:0] to n            |
|                                       |         | 1        | to compute the autocorrelations of F-engine inputs         |
|                                       |         |          | 16n16 (n+1) -1.                                            |
| Channel Reorder Registers             |         | +        | 101110(1111) 1.                                            |
| chan_reorder_dynamic_map1             | 16384   | r/x;     | Datarminas the remanning of input semples to sut           |
| chan_reorder_dynamic_map1             | 10384   | r/w      | Determines the remapping of input samples to out-          |
|                                       |         |          | put samples. I.e., if the first entry is 5, then the first |
|                                       |         |          | sample into the reorder will come out 5th                  |
| Correlation Registers                 |         |          |                                                            |
| corr_0_acc_cnt                        | 4       | r        | 32-bit wrapping accumulation counter, which incre-         |
|                                       |         |          | ments each time a new accumulation is recorded to          |
|                                       |         |          | RAM. There is no buffer locking when correlation           |
|                                       |         |          | data are read, so this counter can be used to ensure       |
|                                       |         |          | that data have not changed during a read.                  |
|                                       |         |          |                                                            |

Table 3.1 – continued from previous page

|                               |                 |                 | rom previous page                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------------------|-----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Name                 | Size<br>(Bytes) | Permis-<br>sion | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| corr_0_acc_len                | 4               | r/w             | Accumulation length, in FPGA clock cycles. To specify an accumulation length as a number of spectra this register should be written with number_of_spectra x frequency_channels_per_spectra. Here the number of frequency channels per spectra is the number output by the correlation subsystem. Glitches may occur (resulting in the no new accumulations for a few seconds) if the value in this register is reduced without re-applying a sync to the correlation module. |
| corr_0_dout                   | 32768           | r/w             | Correlation data buffer. Word [2n] is the real part of the correlation of frequency channel n (after any channel averaging). Word [2n+1] is the imaginary part of this correlation.                                                                                                                                                                                                                                                                                           |
| corr_0_input_sel              | 4               | r/w             | Input selector control register. Bits [5:0] select the unconjugated correlation input. Bits [13:8] select the conjugated correlation input.                                                                                                                                                                                                                                                                                                                                   |
| Delay Registers               |                 |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| delay_ <n>_delay</n>          | 4               | r/w             | The delay applied to stream n. Any value entered in this 32-bit register will be interpretted modulo the maximum supported delay.                                                                                                                                                                                                                                                                                                                                             |
| delay_max_delay               | 4               | r               | Interpretted as a unint32 value, contains the maximum allowed delay, in ADC samples, which may be applied to a data stream.                                                                                                                                                                                                                                                                                                                                                   |
| <b>Equalization Registers</b> |                 |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| eq_core <n>_clip_cnt</n>      | 4               | r               | A count of the number of times a sample has been clipped, for any of F-engine inputs 16n 16 (n+1) -1. This counter is reset only by a global system reset.                                                                                                                                                                                                                                                                                                                    |
| eq_core <n>_coeffs</n>        | 131072          | r/w             | This memory holds coefficients for F-engine streams 16n16(n+1)-1. Coefficients are stored as a [16, n_fft_channels / 8] array, where the first axis (over input number) varies <i>slowest</i> . Coefficients are shared over 8 consecutive frequency channels, with coefficient m being applied to frequency channel m8 (m+1)-1. Coefficients are interpretted with 5 bits below the binary point.                                                                            |
| 40GbE Registers               |                 |                 | ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| eth_ctrl                      | 4               | r/w             | 40GbE control register. Bit 0 is an active high reset of the 40GbE interface core. Bit 1 is an active high transmission enable for the core, which takes effect either after the next packet is sent, or when the force flag is asserted. Bit 18 is an active high reset for statistics provided by the Ethernet core. Bit 19 is an active high force signal, which causes the current transmission enable flag to immediately take effect.                                   |
| eth_forty_gbe_txctr           | 4               | r               | Counter which increments each time a valid end-of-frame is seen on a packet to be transmitted                                                                                                                                                                                                                                                                                                                                                                                 |

Table 3.1 – continued from previous page

|                                       |                 |                 | from previous page                                                                                                                                                                                                                                                                                    |
|---------------------------------------|-----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Name                         | Size<br>(Bytes) | Permis-<br>sion | Description                                                                                                                                                                                                                                                                                           |
| eth_forty_gbe_txfullctr               | 4               | r               | Counter which increments every time the transmission buffer is full                                                                                                                                                                                                                                   |
| eth_forty_gbe_txofctr                 | 4               | r               | Counter which increments on every transmission overflow event                                                                                                                                                                                                                                         |
| eth_forty_gbe_txvldctr                | 4               | r               | Counter which increments with every valid word of data input to the core                                                                                                                                                                                                                              |
| Input Control Registers               |                 |                 |                                                                                                                                                                                                                                                                                                       |
| in-<br>put_bit_stats_histogram_output | 32768           | r/w             | BRAM storing histogram data. Word n in the bottom half of the RAM stores the number of occurances of of ADC sample code n in _even_ numbered ADC samples. Word n in the _top_ half of the RAM stores the number of occurances of ADC sample code n in _odd_ numbered ADC samples.                     |
| input_bit_stats_input_sel             | 4               | r/w             | Input selection. The least significant 6 bits should be set to n to compute the histogram for input n.                                                                                                                                                                                                |
| input_rms_enable                      | 4               | r/w             | Enable statistics recording. If the least-significant bit is 1, statistics will be recorded to RAM.                                                                                                                                                                                                   |
| input_rms_levels                      | 32768           | r/w             | Multi-channel statistics. For the n th 64-bit word, the least signficant 32 bits represent the accumulated ADC power, accumulated over 65536 samples and stored as an unsigned 32-bit integer. The most significant 32 bits represent the sum of 65536 ADC samples stored as a signed 32-bit integer. |
| input_source_sel0                     | 4               | r/w             | Selector control to determine if signal streams carry ADC samples, digital noise samples, or zeros. Streams n=015 is controlled by register bits [2n+1:2n]. Value 0 selects noise; 1 selects ADC; 2 selects zeros.                                                                                    |
| input_source_sel1                     | 4               | r/w             | Selector control to determine if signal streams carry ADC samples, digital noise samples, or zeros. Streams n=1631 is controlled by register bits [2 (n-16)+1:2 (n-16)]. Value 0 selects noise; 1 selects ADC; 2 selects zeros.                                                                       |
| input_source_sel2                     | 4               | r/w             | Selector control to determine if signal streams carry ADC samples, digital noise samples, or zeros. Streams n=3247 is controlled by register bits [2 (n-32) +1:2 (n-32)]. Value 0 selects noise; 1 selects ADC; 2 selects zeros.                                                                      |
| input_source_sel3                     | 4               | r/w             | Selector control to determine if signal streams carry ADC samples, digital noise samples, or zeros. Streams n=4863 is controlled by register bits [2 (n-48)+1:2 (n-48)]. Value 0 selects noise; 1 selects ADC; 2 selects zeros.                                                                       |
| Noise Generator Registers             |                 |                 |                                                                                                                                                                                                                                                                                                       |
| noise_octal_mux0_sel                  | 4               | r/w             | The lower 2 bits define the select signal for the noise multiplexor. If this register has value v, then noise generator v is selected.                                                                                                                                                                |

Table 3.1 – continued from previous page

| B : . N                                              |                 |                 | from previous page                                      |
|------------------------------------------------------|-----------------|-----------------|---------------------------------------------------------|
| Register Name                                        | Size<br>(Bytes) | Permis-<br>sion | Description                                             |
| noise_octal_mux1_sel                                 | 4               | r/w             | The lower 2 bits define the select signal for the noise |
| 11019 <b>0</b> _9 <b>0 tu</b> t_1114111_5 <b>0</b> 1 | '               | 1,              | multiplexor. If this register has value v, then noise   |
|                                                      |                 |                 | generator v is selected.                                |
| noise_octal_mux2_sel                                 | 4               | r/w             | The lower 2 bits define the select signal for the noise |
| noise_octal_mux2_ser                                 | -               | 17 W            | multiplexor. If this register has value v, then noise   |
|                                                      |                 |                 | generator v is selected.                                |
| noise_octal_mux3_sel                                 | 4               | r/w             | The lower 2 bits define the select signal for the noise |
| noise_octai_mux3_sei                                 | 4               | 17 W            | _                                                       |
|                                                      |                 |                 | multiplexor. If this register has value v, then noise   |
|                                                      | 4               |                 | generator v is selected.                                |
| noise_octal_mux4_sel                                 | 4               | r/w             | The lower 2 bits define the select signal for the noise |
|                                                      |                 |                 | multiplexor. If this register has value v, then noise   |
|                                                      |                 |                 | generator v is selected.                                |
| noise_octal_mux5_sel                                 | 4               | r/w             | The lower 2 bits define the select signal for the noise |
|                                                      |                 |                 | multiplexor. If this register has value v, then noise   |
|                                                      |                 |                 | generator v is selected.                                |
| noise_octal_mux6_sel                                 | 4               | r/w             | The lower 2 bits define the select signal for the noise |
|                                                      |                 |                 | multiplexor. If this register has value v, then noise   |
|                                                      |                 |                 | generator v is selected.                                |
| noise_octal_mux7_sel                                 | 4               | r/w             | The lower 2 bits define the select signal for the noise |
|                                                      |                 |                 | multiplexor. If this register has value v, then noise   |
|                                                      |                 |                 | generator v is selected.                                |
| noise_seeds0                                         | 4               | r/w             | Noise generator seed values. If the 32-bit value in     |
|                                                      |                 |                 | this register is v, the seed for the first noise gener- |
|                                                      |                 |                 | ator is (using Verilog syntax) {8'h5c, v[7:0],          |
|                                                      |                 |                 | v[0:7], 8'ha3}. The seed for the second noise           |
|                                                      |                 |                 | generator is {8'h5c, v[15:8], v[8:15],                  |
|                                                      |                 |                 | 8'ha3}. The seed for the third noise gen-               |
|                                                      |                 |                 | erator is {8'h5c, v[23:16], v[16:23],                   |
|                                                      |                 |                 | 8'ha3}. The seed for the fourth noise generator is      |
|                                                      |                 |                 | {8'h5c, v[31:24], v[24:31], 8'ha3}                      |
| Packetizer Registers                                 |                 |                 |                                                         |
| packetizer_ants                                      | 262144          | r/w             | Antenna header entry map. Word n``contains              |
|                                                      |                 |                 | the header antenna ID field for                         |
|                                                      |                 |                 | sample ``n in a transmission period. This field         |
|                                                      |                 |                 | is only relevant for samples accompanied by valid       |
|                                                      |                 |                 | and header flags.                                       |
| packetizer_chans                                     | 262144          | r/w             | Channel ID header entry map. Bits [23:0] of word        |
|                                                      |                 |                 | n contain the header channel ID field for sample n      |
|                                                      |                 |                 | in a transmission period. This header field should      |
|                                                      |                 |                 | hold the index of the first channel in a packet. Bits   |
|                                                      |                 |                 | [31:24] contain the header channel block index          |
|                                                      |                 |                 | field for this sample. These field is only relevant for |
|                                                      |                 |                 | samples accompanied by valid and header flags.          |
| packetizer_flags                                     | 262144          | r/w             | Packet flags. For word n, bit 0 is an active high flag  |
|                                                      |                 |                 | which indicates that sample n in a transmission pe-     |
|                                                      |                 |                 | riod is a packet header. Bit 8 is an active high flag   |
|                                                      |                 |                 | which indicates that this word is valid and should be   |
|                                                      |                 |                 | transmitted. Bit 16 is an active high flag indicating   |
|                                                      |                 |                 | that this word is the last in a packet.                 |
|                                                      | <u> </u>        |                 | continues on next page                                  |

Table 3.1 – continued from previous page

| Table 3.1 – continued from previous page |         |         |                                                                                                    |  |
|------------------------------------------|---------|---------|----------------------------------------------------------------------------------------------------|--|
| Register Name                            | Size    | Permis- | Description                                                                                        |  |
|                                          | (Bytes) | sion    |                                                                                                    |  |
| packetizer_ips                           | 262144  | r/w     | IP Destination address map. Word n contains the IP                                                 |  |
|                                          |         |         | address to which sample n in a transmission period                                                 |  |
|                                          |         |         | should be sent. Only entries accompanied by valid                                                  |  |
|                                          |         |         | and end of frame flags result in a packet's des-                                                   |  |
|                                          |         |         | tination being set from this register.                                                             |  |
| packetizer_n_chans                       | 4       | r/w     | 32-bit n_chans header field for F-engine output                                                    |  |
|                                          |         |         | data packets, indicating the number of frequency                                                   |  |
|                                          |         |         | channels per packet.                                                                               |  |
| packetizer_n_pols                        | 4       | r/w     | 32-bit n_pols header field for F-engine output                                                     |  |
|                                          |         |         | data packets, indicating the number of antenna-                                                    |  |
|                                          |         |         | polarizations present in a packet.                                                                 |  |
| packetizer_ports                         | 262144  | r/w     | UDP Destination port map. For word n, bits                                                         |  |
|                                          |         |         | [15:0] contain the UDP port to which sample n                                                      |  |
|                                          |         |         | in a transmission period should be sent. Only sam-                                                 |  |
|                                          |         |         | ples accompanied by valid and end of frame                                                         |  |
|                                          |         |         | flags result in a packet's destination being set from                                              |  |
| DVD D                                    |         |         | this register.                                                                                     |  |
| PFB Registers                            |         | ļ.,     | DED 1                                                                                              |  |
| pfb_ctrl                                 | 4       | r/w     | PFB control register. Bit 18 is an active-high reset                                               |  |
|                                          |         |         | for overflow statistics counters. Bits 15:0 hold the                                               |  |
|                                          |         |         | FFT shift schedule for the PFB processing pipeline,                                                |  |
|                                          |         |         | with bit n an active high shift signal for the n th FFT                                            |  |
| Cl. Cl.16                                | 4       |         | stage.                                                                                             |  |
| pfb_pfb16x_ <n>_status</n>               | 4       | r       | A 32-bit counter which, for register name suffix                                                   |  |
|                                          |         |         | <n>_status increments every time an FFT over-</n>                                                  |  |
|                                          |         |         | flow event is detected in any of FFT channels 16n.<br>.16 (n+1) -1. Resets only when commanded via |  |
|                                          |         |         | the PFB control register, and will wrap once the                                                   |  |
|                                          |         |         | maximum value is reached.                                                                          |  |
| Post-EQ Test Vector Genera-              |         |         | maximum value is reacticu.                                                                         |  |
| tor Registers                            |         |         |                                                                                                    |  |
| post_eq_tvg_core <n>_tv</n>              | 524288  | r/w     | This memory holds 4+4 bit complex test                                                             |  |
| Post_eq_ttg_core <ii>_tt</ii>            | 32.200  | " "     | vector streams for F-engine streams 16n                                                            |  |
|                                          |         |         | 16 (n+1) -1. Test vectors are stored as a [16,                                                     |  |
|                                          |         |         | n_fft_channels] array, where the first axis                                                        |  |
|                                          |         |         | (over input number) varies <i>slowest</i> , and vectors                                            |  |
|                                          |         |         | are stored in order of increasing FFT channel. An                                                  |  |
|                                          |         |         | 8-bit word in location [m, c] is interpretted as a                                                 |  |
|                                          |         |         | 4+4 bit complex value for channel c of F-engine                                                    |  |
|                                          |         |         | stream 16n + m. The most significant 4 bits are                                                    |  |
|                                          |         |         | interpretted as the real part of the complex value.                                                |  |
| post_eq_tvg_tvg_en                       | 4       | r/w     | Test vector multiplexor control. If the least sig-                                                 |  |
|                                          |         |         | nificant bit is 1, ADC data will be replaced with                                                  |  |
|                                          |         |         | software-controllable test vectors.                                                                |  |
| Synchronization Registers                | 1       |         |                                                                                                    |  |
|                                          | 1       | I       | I .                                                                                                |  |

Table 3.1 – continued from previous page

| Pogistor Namo        | Size    | Permis- | Description                                             |
|----------------------|---------|---------|---------------------------------------------------------|
| Register Name        | (Bytes) | sion    | Description                                             |
| sync_ctrl            | 4       | r/w     | Timing control register. Bit 0: active high enable      |
| sync_cur             | 7       | 17 W    | allowing telescope time counter to be loaded from       |
|                      |         |         | telescope time load registers on next synchroniza-      |
|                      |         |         | tion pulse. Bit 1: When transitioned from 0 to 1,       |
|                      |         |         | forces telescope time counter to be loaded from tele-   |
|                      |         |         | scope time load registers immediately. Bit 2: ac-       |
|                      |         |         | tive high telescope time counter reset. Bit 3: active   |
|                      |         |         |                                                         |
|                      |         |         | high reset for error counters. Bit 4: active high arm   |
|                      |         |         | signal, which causes a global system reset, released    |
|                      |         |         | on the next synchronization pulse; a system sync on     |
|                      |         |         | the next synchronization pulse. Bit 5: When transit-    |
|                      |         |         | tioned from 0 to 1, emulates the arrival of an exter-   |
|                      |         |         | nal sync pulse. Bit 6: When transittioned from 0 to     |
|                      | 4       |         | 1, arms noise generator seed loaders.                   |
| sync_ext_sync_count  | 4       | r       | Number of external synchronization pulses received.     |
| sync_ext_sync_period | 4       | r       | Measured number of FPGA clock ticks between pre-        |
|                      |         |         | vious two external synchronization pulses.              |
| sync_ext_sync_tt_lsb | 4       | r       | Least significant 32 bits of the telescope time         |
|                      |         |         | counter, at the point of the last external synchroniza- |
|                      |         |         | tion pulse.                                             |
| sync_ext_sync_tt_msb | 4       | r       | Most significant 32 bits of the telescope time          |
|                      |         |         | counter, at the point of the last external synchroniza- |
|                      |         |         | tion pulse.                                             |
| sync_int_sync_count  | 4       | r       | Number of synchronization pulses emitted via            |
|                      |         |         | GPIO.                                                   |
| sync_latency         | 4       | r       | Measured latecy, in FPGA clock ticks, between           |
|                      |         |         | transmitting a synchronization pulse and receiving      |
|                      |         |         | it from the timing distribution system.                 |
| sync_sync_div_bits   | 4       | r       | Holds the log2 value of the sync period – i.e. the rate |
|                      |         |         | at which sync pulses are emitted from the board via     |
|                      |         |         | GPIO – in FPGA clock ticks.                             |
| sync_tt_load_lsb     | 4       | r/w     | Telescope time load register. Least significant 32      |
|                      |         |         | bits to load to the telescope time counter.             |
| sync_tt_load_msb     | 4       | r/w     | Telescope time load register. Most significant 32 bits  |
|                      |         |         | to load to the telescope time counter.                  |
| sync_tt_lsb          | 4       | r       | Least significant 32 bits of the telescope time         |
|                      |         |         | counter.                                                |
| sync_tt_msb          | 4       | r       | Most significant 32 bits of the telescope time          |
| -                    |         |         | counter.                                                |
| sync_uptime_msb      | 4       | r       | Board uptime, in units of 2^32 FPGA clock ticks.        |
| Version Registers    |         |         | * '                                                     |
| version_timestamp    | 4       | r       | Unix timestamp, in integer seconds, when firmware       |
|                      |         |         | was last compiled.                                      |
| version_version      | 4       | r       | Version register. Bits [31:24]: major version.          |
|                      |         |         | Bits [23:16]: minor version. Bits [15:8]: re-           |
|                      |         |         | vision. Bits [7:0]: buxfix.                             |
|                      |         |         | , Island Bitto [ 1 . O ] . Outline                      |

# **CHAPTER**

# **FOUR**

# **INDICES AND TABLES**

- genindex
- modindex
- search

# **INDEX**

| A                                                                                     | <pre>get_build_time() (lwa_f.blocks.fpga.Fpga method), 7</pre>                                                 |
|---------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
| Adc (class in lwa_f.blocks.adc), 10 add_arp_entry() (lwa_f.blocks.eth.Eth method), 23 | get_coeffs() (lwa_f.blocks.eq.Eq method), 20                                                                   |
| arm_noise() (lwa_f.blocks.sync.Sync method), 8                                        | <pre>get_delay() (lwa_f.blocks.delay.Delay method), 15</pre>                                                   |
| arm_sync() (lwa_f.blocks.sync.Sync method), 8                                         | <pre>get_error_count() (lwa_f.blocks.sync.Sync</pre>                                                           |
| assign_output() (lwa_f.blocks.noisegen.NoiseGen                                       | method), 8                                                                                                     |
| method), 14                                                                           | <pre>get_firmware_version()</pre>                                                                              |
| AutoCorr (class in lwa_f.blocks.autocorr), 16                                         | (lwa_f.blocks.fpga.Fpga method), 7                                                                             |
| С                                                                                     | get_histogram() (lwa_f.blocks.input.Input method),  12                                                         |
| <pre>calibrate() (lwa_f.blocks.adc.Adc method), 10</pre>                              | <pre>get_latency() (lwa_f.blocks.sync.Sync method), 9 get_max_delay() (lwa_f.blocks.delay.Delay</pre>          |
| ChanReorder (class in lwa_f.blocks.chanreorder), 21                                   | method), 15                                                                                                    |
| clip_count() (lwa_f.blocks.eq.Eq method), 20                                          | get_new_corr() (lwa_f.blocks.corr.Corr method), 18                                                             |
| configure_output()                                                                    | <pre>get_new_spectra()</pre>                                                                                   |
| (lwa_f.snap2_fengine.Snap2Fengine method),                                            | (lwa_f.blocks.autocorr.AutoCorr method),                                                                       |
| Corr (class in lwa_f.blocks.corr), 17                                                 | 16                                                                                                             |
| count_ext() (lwa_f.blocks.sync.Sync method), 8                                        | <pre>get_output_assignment()</pre>                                                                             |
| count_int() (lwa_f.blocks.sync.Sync method), 8                                        | (lwa_f.blocks.noisegen.NoiseGen method),                                                                       |
|                                                                                       | 14                                                                                                             |
| D                                                                                     | <pre>get_packet_info()       (lwa_f.blocks.packetizer.Packetizer method), 22</pre>                             |
| Delay (class in lwa_f.blocks.delay), 15                                               | get_seed() (lwa_f.blocks.noisegen.NoiseGen                                                                     |
| disable_tx() (lwa_f.blocks.eth.Eth method), 23                                        | method), 14                                                                                                    |
| E                                                                                     | <pre>get_snapshot() (lwa_f.blocks.adc.Adc method), 10</pre>                                                    |
| <del></del>                                                                           | <pre>get_snapshot_interleaved()</pre>                                                                          |
| enable_tx() (lwa_f.blocks.eth.Eth method), 23                                         | (lwa_f.blocks.adc.Adc method), 10                                                                              |
| Eq (class in lwa_f.blocks.eq), 20 EqTvg (class in lwa_f.blocks.eqtvg), 19             | get_status() (lwa_f.blocks.autocorr.AutoCorr                                                                   |
| Eth (class in lwa_f.blocks.eqivg), 19 Eth (class in lwa_f.blocks.eth), 23             | method), 17                                                                                                    |
| Ten (class in twa_J.blocks.cm), 25                                                    | <pre>get_status() (lwa_f.blocks.corr.Corr method), 18 get_status() (lwa_f.blocks.delay.Delay method), 15</pre> |
| F                                                                                     | get_status() (lwa_f.blocks.eq.Eq method), 20                                                                   |
| Fpga (class in lwa_f.blocks.fpga), 7                                                  | get_status() (lwa_f.blocks.eqtvg.EqTvg method), 19                                                             |
|                                                                                       | get_status() (lwa_f.blocks.eth.Eth method), 23                                                                 |
| G                                                                                     | get_status() (lwa_f.blocks.fpga.Fpga method), 7                                                                |
| <pre>get_acc_len() (lwa_f.blocks.autocorr.AutoCorr</pre>                              | <pre>get_status() (lwa_f.blocks.input.Input method), 12</pre>                                                  |
| method), 16                                                                           | get_status() (lwa_f.blocks.noisegen.NoiseGen                                                                   |
| <pre>get_acc_len() (lwa_f.blocks.corr.Corr method), 17</pre>                          | method), 14                                                                                                    |
| <pre>get_all_histograms() (lwa_f.blocks.input.Input</pre>                             | <pre>get_status() (lwa_f.blocks.pfb.Pfb method), 16 get_status() (lwa_f.blocks.sync.Sync method), 9</pre>      |
| method), 12                                                                           | get_status() (lwa_f.snap2_fengine.Snap2Fengine                                                                 |
| <pre>get_bit_stats() (lwa_f.blocks.input.Input method),</pre>                         | method), 6                                                                                                     |
| 1 2                                                                                   | · · · · · · · · · · · · · · · · · · ·                                                                          |

```
print_histograms()
get switch positions()
                                                                                   (lwa_f.blocks.input.Input
         (lwa f.blocks.input.Input method), 13
                                                              method), 13
                                                     print status all()
Н
                                                              (lwa_f.snap2_fengine.Snap2Fengine method),
hostname
             (lwa f.snap2 fengine.Snap2Fengine
                                                at-
                                                     print sweep() (lwa f.blocks.adc.Adc method), 11
        tribute), 6
                                                                        (lwa f.snap2 fengine.Snap2Fengine
                                                     program()
                                                              method), 6
initialize() (lwa_f.blocks.adc.Adc method), 11
                                                     R
                      (lwa f.blocks.autocorr.AutoCorr
initialize()
                                                      read reorder() (lwa f.blocks.chanreorder.ChanReorder
        method), 17
                                                              method), 21
initialize()(lwa_f.blocks.chanreorder.ChanReorder
        method), 21
                                                     read stream tvg()
                                                                                 (lwa_f.blocks.eqtvg.EqTvg
initialize() (lwa_f.blocks.corr.Corr method), 18
                                                              method), 19
                                                     reset() (lwa_f.blocks.adc.Adc method), 11
initialize() (lwa f.blocks.delay.Delay method), 15
                                                      reset () (lwa f.blocks.eth.Eth method), 24
initialize() (lwa f.blocks.eq.Eq method), 21
                                                     reset error count()
                                                                                   (lwa f.blocks.sync.Sync
initialize() (lwa_f.blocks.eqtvg.EqTvg method), 19
initialize() (lwa_f.blocks.eth.Eth method), 24
                                                              method), 9
                                                     reset_telescope_time() (lwa_f.blocks.sync.Sync
initialize() (lwa_f.blocks.input.Input method), 13
                                                              method), 9
initialize()
                     (lwa_f.blocks.noisegen.NoiseGen
        method), 14
                                                     S
initialize() (lwa_f.blocks.pfb.Pfb method), 16
initialize() (lwa_f.blocks.sync.Sync method), 9
                                                     set_acc_len()
                                                                            (lwa_f.blocks.autocorr.AutoCorr
initialize()
                  (lwa_f.snap2_fengine.Snap2Fengine
                                                              method), 17
        method), 6
                                                     set_acc_len() (lwa_f.blocks.corr.Corr method), 18
Input (class in lwa_f.blocks.input), 12
                                                      set_arp_table() (lwa_f.blocks.eth.Eth method), 24
is_programmed() (lwa_f.blocks.fpga.Fpga method),
                                                     set_channel_order()
                                                              (lwa_f.blocks.chanreorder.ChanReorder
                                                              method), 21
L
                                                      set_coeffs() (lwa_f.blocks.eq.Eq method), 21
load_telescope_time() (lwa_f.blocks.sync.Sync
                                                     set_delay() (lwa_f.blocks.delay.Delay method), 15
        method), 9
                                                      set delays() (lwa f.blocks.adc.Adc method), 11
logger (lwa f.snap2 fengine.Snap2Fengine attribute),
                                                                           (lwa f.blocks.noisegen.NoiseGen
                                                     set_seed()
                                                              method), 14
                                                     Snap2Fengine (class in lwa_f.snap2_fengine), 6
M
                                                      status_reset() (lwa_f.blocks.eth.Eth method), 24
MIN_DELAY (lwa_f.blocks.delay.Delay attribute), 15
                                                      sw_sync() (lwa_f.blocks.sync.Sync method), 9
mmcm is locked() (lwa f.blocks.adc.Adc method),
                                                     Sync (class in lwa_f.blocks.sync), 8
         11
                                                      sync() (lwa_f.blocks.adc.Adc method), 11
Ν
                                                     Т
\verb|n_parallel_chans| (\textit{lwa\_f.blocks.chanreorder.ChanReorder\_} \\ \verb|disable()| (\textit{lwa\_f.blocks.eqtvg.EqTvg}| \textit{method}),
        attribute), 21
NoiseGen (class in lwa_f.blocks.noisegen), 13
                                                     tvg_enable() (lwa_f.blocks.eqtvg.EqTvg method), 19
                                                     tvg_is_enabled()
                                                                                 (lwa_f.blocks.eqtvg.EqTvg
Р
                                                              method), 19
Packetizer (class in lwa_f.blocks.packetizer), 22
                                                     U
period() (lwa_f.blocks.sync.Sync method), 9
Pfb (class in lwa f.blocks.pfb), 16
                                                     uptime()(lwa_f.blocks.sync.Sync method), 9
plot_corr() (lwa_f.blocks.corr.Corr method), 18
                                                     use adc() (lwa f.blocks.input.Input method), 13
plot_histogram()
                             (lwa f.blocks.input.Input
                                                     use_noise()(lwa_f.blocks.input.Input method), 13
        method), 13
                                                     use zero() (lwa f.blocks.input.Input method), 13
plot_spectra()
                      (lwa f.blocks.autocorr.AutoCorr
        method), 17
```

40 Index

# W

Index 41