# RedPitaya

# FPGA memory map

| Written by   | Revision Description                                        | Version | Date                   |
|--------------|-------------------------------------------------------------|---------|------------------------|
| Matej Oblak  | Initial                                                     | 0.1     | 08/11/13               |
| Matej Oblak  | Release1 update                                             | 0.2     | 16/12/13               |
| Matej Oblak  | ASG - added burst mode<br>ASG - buffer read pointer readout |         | Dec. 2014<br>Jan. 2015 |
| Matej Oblak  | AXI master documented                                       |         | Feb. 2015              |
| Iztok Jeras  | Added debounce delay register                               |         | Mar. 2015              |
| Iztok Jeras  | Added digital loopback, pre trigger status                  |         | Apr. 2015              |
| Iztok Jeras  | Removed XADC registers<br>GPIO[0] is now R/W                |         | Avg. 2015              |
| Ulrich Habel | RadioBox added                                              | 0.3     | Dec. 2015              |
|              |                                                             |         |                        |
|              |                                                             |         |                        |
|              |                                                             |         |                        |
|              |                                                             |         |                        |

### **Table of Contents**

| About Document                   | 3 |
|----------------------------------|---|
| FPGA Memory Map                  |   |
| Red Pitaya Modules               | 3 |
| Housekeeping                     |   |
| Oscilloscope                     |   |
| Arbitrary Signal Generator (ASG) |   |
| PID Controller                   |   |
| Analog Mixed Signals (AMS)       |   |
| Daisy Chain                      |   |
| Power Test                       |   |

#### **About Document**

Red Pitaya HDL design has multiple functions, which are configured by registers. It also uses memory locations to store capture data and generate output signals. All of this are described in this document. Memory location is written in a way that is seen by SW.

#### **FPGA Memory Map**

The table describes address space partitioning implemented on FPGA via AXI GP0 interface. All registers have offsets aligned to 4 bytes and are 32 -bit wide. Granularity is 32-bit, meaning that minimum transfer size is 4 bytes. The organization is little-endian.

The memory block is divided into 8 parts. Each part is occupied by individual IP core. Address space of individual application is described in the subsection below. The size of each IP core address space is 4MByte.

For additional informations and better understanding check other documents (schematics, specifications...).

|       | Start      | End        | Module Name                      |
|-------|------------|------------|----------------------------------|
| CS[0] | 0x40000000 | 0x400FFFFF | Housekeeping                     |
| CS[1] | 0x40100000 | 0x401FFFFF | Oscilloscope                     |
| CS[2] | 0x40200000 | 0x402FFFFF | Arbitrary signal generator (ASG) |
| CS[3] | 0x40300000 | 0x403FFFFF | PID controller                   |
| CS[4] | 0x40400000 | 0x404FFFFF | Analog mixed signals (AMS)       |
| CS[5] | 0x40500000 | 0x405FFFFF | ( not assigned )                 |
| CS[6] | 0x40600000 | 0x406FFFFF | RadioBox (RB)                    |
| CS[7] | 0x40700000 | 0x407FFFFF | ( not assigned )                 |

#### **Red Pitaya Modules**

Here are described submodules used in Red Pitaya FPGA logic.

### Housekeeping

| offset | description                               | bits  | R/W |
|--------|-------------------------------------------|-------|-----|
| 0x0    | ID                                        |       |     |
|        | Reserved                                  | 31:4  | R   |
|        | Design ID 0-prototype0, 1-release1        | 3:0   | R   |
| 0x4    | DNA part1                                 |       |     |
|        | DNA[31:0]                                 | 31:0  | R   |
| 0x8    | DNA part2                                 |       |     |
|        | Reserved                                  | 31:25 | R   |
|        | DNA[56:32]                                | 24:0  | R   |
| 0xC    | Digital Loopback                          |       |     |
|        | Reserved                                  | 31:1  | R   |
|        | digital_loop                              | 0     | R/W |
| 0x10   | Expansion connector direction P           |       |     |
|        | Reserved                                  | 31:8  | R   |
|        | Direction for P lines                     | 7:0   | R/W |
|        | 1-out<br>0-in                             |       |     |
| 0x14   |                                           |       |     |
| UX14   | Expansion connector direction N  Reserved | 31:8  | R   |
|        | Direction for N lines                     |       | R/W |
|        | 1-out                                     | 7:0   | K/W |
|        | 0-in                                      |       |     |
| 0x18   | Expansion connector output P              |       |     |
|        | Reserved                                  | 31:8  | R   |
|        | P pins output                             | 7:0   | R/W |
| 0x1C   | Expansion connector output N              |       |     |
|        | Reserved                                  | 31:8  | R   |
|        | N pins output                             | 7:0   | R/W |
| 0x20   | Expansion connector input P               |       |     |
|        | Reserved                                  | 31:8  | R   |
|        | P pins input                              | 7:0   | R   |
| 0x24   | Expansion connector input N               |       |     |
|        | Reserved                                  | 31:8  | R   |
|        | N pins input                              | 7:0   | R   |
| 0x30   | LED control                               |       |     |
|        | Reserved                                  | 31:8  | R   |

LEDs 7-0 7:0 R/W

#### Oscilloscope

| offset | description                                                                                                                                                                                                                                                                                                                                             | bits  | R/W |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----|
| 0x0    | Configuration                                                                                                                                                                                                                                                                                                                                           |       |     |
|        | Reserved                                                                                                                                                                                                                                                                                                                                                | 31:3  | R   |
|        | Trigger status before acquire ends (0 – pre trigger, 1 – post trigger)                                                                                                                                                                                                                                                                                  | 2     | R   |
|        | Reset write state machine                                                                                                                                                                                                                                                                                                                               | 1     | W   |
|        | Start writing data into memory (ARM trigger).                                                                                                                                                                                                                                                                                                           | 0     | W   |
| 0x4    | Trigger source                                                                                                                                                                                                                                                                                                                                          |       |     |
|        | Selects trigger source for data capture. When trigger delay is ended value goes to 0.                                                                                                                                                                                                                                                                   |       |     |
|        | Reserved                                                                                                                                                                                                                                                                                                                                                | 31:4  | R   |
|        | Trigger source: 1-trig immediately 2-ch A threshold positive edge 3-ch A threshold negative edge 4-ch B threshold positive edge 5-ch B threshold negative edge 6-external trigger positive edge - DIOO_P pin 7-external trigger negative edge 8-arbitrary wave generator application positive edge 9-arbitrary wave generator application negative edge | 3:0   | R/W |
| 0x8    | Ch A threshold                                                                                                                                                                                                                                                                                                                                          |       |     |
|        | Reserved                                                                                                                                                                                                                                                                                                                                                | 31:14 | R   |
|        | Ch A threshold, makes trigger when ADC value cross this value                                                                                                                                                                                                                                                                                           | 13:0  | R/W |
| 0xC    | Ch B threshold                                                                                                                                                                                                                                                                                                                                          |       |     |
|        | Reserved                                                                                                                                                                                                                                                                                                                                                | 31:14 | R   |
|        | Ch B threshold, makes trigger when ADC value cross this value                                                                                                                                                                                                                                                                                           | 13:0  | R/W |
| 0x10   | Delay after trigger                                                                                                                                                                                                                                                                                                                                     |       |     |
|        | Number of decimated data after trigger written into memory                                                                                                                                                                                                                                                                                              | 31:0  | R/W |
| 0x14   | Data decimation                                                                                                                                                                                                                                                                                                                                         |       |     |
|        | Decimate input data, uses data average                                                                                                                                                                                                                                                                                                                  |       |     |
|        | Reserved                                                                                                                                                                                                                                                                                                                                                | 31:17 | R   |
|        | Data decimation, supports only this values: 1,8, 64,1024,8192,65536. If other value is written data will NOT be correct.                                                                                                                                                                                                                                | 16:0  | R/W |
| 0x18   | Write pointer - current                                                                                                                                                                                                                                                                                                                                 |       |     |
|        | Reserved                                                                                                                                                                                                                                                                                                                                                | 31:14 | R   |
|        | Current write pointer                                                                                                                                                                                                                                                                                                                                   | 13:0  | R   |
| 0x1C   | Write pointer - trigger                                                                                                                                                                                                                                                                                                                                 |       |     |
|        | Reserved                                                                                                                                                                                                                                                                                                                                                | 31:14 | R   |

|      | Write pointer at time when trigger arrived                                                                                                                                     | 13:0  | R   |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----|
| 0x20 | Ch A hysteresis                                                                                                                                                                |       |     |
|      | Reserved                                                                                                                                                                       | 31:14 | R   |
|      | Ch A threshold hysteresis. Value must be outside to enable trigger again.                                                                                                      | 13:0  | R/W |
| 0x24 | Ch B hysteresis                                                                                                                                                                |       |     |
|      | Reserved                                                                                                                                                                       | 31:14 | R   |
|      | Ch B threshold hysteresis. Value must be outside to enable trigger again.                                                                                                      | 13:0  | R/W |
| 0x28 | Other                                                                                                                                                                          |       |     |
|      | Reserved                                                                                                                                                                       | 31:1  | R   |
|      | Enable signal average at decimation                                                                                                                                            | 0     | R/W |
| 0x2C | PreTrigger Counter                                                                                                                                                             |       |     |
|      | This unsigned counter holds the number of samples captured between the start of acquire and trigger. The value does not overflow, instead it stops incrementing at 0xffffffff. | 31:0  | R   |
| 0x30 | CH A Equalization filter                                                                                                                                                       |       |     |
|      | Reserved                                                                                                                                                                       | 31:18 | R   |
|      | AA Coefficient                                                                                                                                                                 | 17:0  | R/W |
| 0x34 | CH A Equalization filter                                                                                                                                                       |       |     |
|      | Reserved                                                                                                                                                                       | 31:25 | R   |
|      | BB Coefficient                                                                                                                                                                 | 24:0  | R/W |
| 0x38 | CH A Equalization filter                                                                                                                                                       |       |     |
|      | Reserved                                                                                                                                                                       | 31:25 | R   |
|      | KK Coefficient                                                                                                                                                                 | 24:0  | R/W |
| 0x3C | CH A Equalization filter                                                                                                                                                       |       |     |
|      | Reserved                                                                                                                                                                       | 31:25 | R   |
|      | PP Coefficient                                                                                                                                                                 | 24:0  | R/W |
| 0x40 | CH B Equalization filter                                                                                                                                                       |       |     |
|      | Reserved                                                                                                                                                                       | 31:18 | R   |
|      | AA Coefficient                                                                                                                                                                 | 17:0  | R/W |
| 0x44 | CH B Equalization filter                                                                                                                                                       |       |     |
|      | Reserved                                                                                                                                                                       | 31:25 | R   |
|      | BB Coefficient                                                                                                                                                                 | 24:0  | R/W |
| 0x48 | CH B Equalization filter                                                                                                                                                       |       |     |
|      | Reserved                                                                                                                                                                       | 31:25 | R   |
|      | KK Coefficient                                                                                                                                                                 | 24:0  | R/W |
| 0x4C | CH B Equalization filter                                                                                                                                                       |       |     |

|      | Reserved                                                                                                             | 31:25 | R   |
|------|----------------------------------------------------------------------------------------------------------------------|-------|-----|
|      | PP Coefficient                                                                                                       | 24:0  | R/W |
| 0x50 | CH A AXI lower address                                                                                               |       |     |
|      | Starting writing address                                                                                             | 31:0  | R/W |
| 0x54 | CH A AXI upper address                                                                                               |       |     |
|      | Address where it jumps to lower                                                                                      | 31:0  | R/W |
| 0x58 | CH A AXI delay after trigger                                                                                         |       |     |
|      | Number of decimated data after trigger written into memory                                                           | 31:0  | R/W |
| 0x5C | CH A AXI enable master                                                                                               |       |     |
|      | Reserved                                                                                                             | 31:1  | R   |
|      | Enable AXI master                                                                                                    | 0     | R/V |
| 0x60 | CH A AXI write pointer - trigger                                                                                     |       |     |
|      | Write pointer at time when trigger arrived                                                                           | 31:0  | R   |
| 0x64 | CH A AXI write pointer - current                                                                                     |       |     |
|      | Current write pointer                                                                                                | 31:0  | R   |
| 0x70 | CH B AXI lower address                                                                                               |       |     |
|      | Starting writing address                                                                                             | 31:0  | R/V |
| 0x74 | CH B AXI upper address                                                                                               |       |     |
|      | Address where it jumps to lower                                                                                      | 31:0  | R/V |
| 0x78 | CH B AXI delay after trigger                                                                                         |       |     |
|      | Number of decimated data after trigger written into memory                                                           | 31:0  | R/V |
| 0x7C | CH B AXI enable master                                                                                               |       |     |
|      | Reserved                                                                                                             | 31:1  | R   |
|      | Enable AXI master                                                                                                    | 0     | R/V |
| 0x80 | CH B AXI write pointer - trigger                                                                                     |       |     |
|      | Write pointer at time when trigger arrived                                                                           | 31:0  | R   |
| 0x84 | CH B AXI write pointer - current                                                                                     |       |     |
|      | Current write pointer                                                                                                | 31:0  | R   |
| 0x90 | Trigger debouncer time                                                                                               |       |     |
|      | Number of ADC clock periods trigger is disabled after activation reset value is decimal 62500 or equivalent to 0.5ms | 19:0  | R/V |
| 0xA0 | Accumulator data sequence length                                                                                     |       |     |
|      | Reserved                                                                                                             | 31:14 | R   |
| 0xA4 | Accumulator data offset corection ChA                                                                                |       |     |
|      | Reserved                                                                                                             | 31:14 | R   |
|      | signed offset value                                                                                                  | 13:0  | R/V |
| 0xA8 | Accumulator data offset corection ChB                                                                                |       |     |
|      | Reserved                                                                                                             | 31:14 | R   |

|             | signed offset value       | 13:0  | R/W |
|-------------|---------------------------|-------|-----|
| 0x10000   1 | Memory data (16k samples) |       |     |
|             | Reserved                  | 31:16 | R   |
|             | Captured data for ch A    | 15:0  | R   |
|             | Memory data (16k samples) |       |     |
|             | Reserved                  | 31:16 | R   |
|             | Captured data for ch B    | 15:0  | R   |

# Arbitrary Signal Generator (ASG)

| offset | description                                                                                                                                                          | bits  | R/W |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----|
| 0x0    | Configuration                                                                                                                                                        |       |     |
|        | Reserved                                                                                                                                                             | 31:25 | R   |
|        | ch B external gated repetitions                                                                                                                                      | 24    | R/W |
|        | ch B set output to 0                                                                                                                                                 | 23    | R/W |
|        | ch B SM reset                                                                                                                                                        | 22    | R/W |
|        | Reserved                                                                                                                                                             | 21    | R/W |
|        | ch B SM wrap pointer (if disabled starts at address 0)                                                                                                               | 20    | R/V |
|        | ch B trigger selector: (don't change when SM is active) 1-trig immediately 2-external trigger positive edge - DIO0_P pin 3-external trigger negative edge            | 19:16 | R/V |
|        | Reserved                                                                                                                                                             | 15:9  | R   |
|        | ch A external gated bursts                                                                                                                                           | 8     | R/V |
|        | ch A set output to 0                                                                                                                                                 | 7     | R/V |
|        | ch A SM reset                                                                                                                                                        | 6     | R/V |
|        | Reserved                                                                                                                                                             | 5     | R/V |
|        | ch A SM wrap pointer (if disabled starts at address 0)                                                                                                               | 4     | R/V |
|        | ch A trigger selector: (don't change when SM is active) 1-trig immediately 2-external trigger positive edge - DIO0_P pin 3-external trigger negative edge            | 3:0   | R/V |
| 0x4    | Ch A amplitude scale and offset                                                                                                                                      |       |     |
|        | out = $\frac{\text{data*scale}}{0x2000 + \text{offset}}$                                                                                                             |       |     |
|        | Reserved                                                                                                                                                             | 31:30 | R   |
|        | Amplitude offset                                                                                                                                                     | 29:16 | R/V |
|        | Reserved                                                                                                                                                             | 15:14 | R   |
|        | Amplitude scale. 0x2000 == multiply by 1. Unsigned                                                                                                                   | 13:0  | R/V |
| 0x8    | Ch A counter wrap                                                                                                                                                    |       |     |
|        | Reserved                                                                                                                                                             | 31:30 | R   |
|        | Value where counter wraps around. Depends on SM wrap setting. If it is 1 new value is get by wrap, if value is 0 counter goes to offset value. 16 bits for decimals. | 29:0  | R/V |
| 0xC    | Ch A start offset                                                                                                                                                    |       |     |
|        | Reserved                                                                                                                                                             | 31:30 | R   |
|        | Counter start offset. Start offset when trigger arrives. 16 bits for decimals.                                                                                       | 29:0  | R/V |

| 0x10 | Ch A counter step                                                                                                                                                    |       |     |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----|
|      | Reserved                                                                                                                                                             | 31:30 | R   |
|      | Counter step. 16 bits for decimals.                                                                                                                                  | 29:0  | R/W |
| 0x14 | Ch A buffer current read pointer                                                                                                                                     |       |     |
|      | Reserved                                                                                                                                                             | 31:16 | R   |
|      | Read pointer                                                                                                                                                         | 15:2  | R/W |
|      | Reserved                                                                                                                                                             | 1:0   | R   |
| 0x18 | Ch A number of read cycles in one burst                                                                                                                              |       |     |
|      | Reserved                                                                                                                                                             | 31:16 | R   |
|      | Number of repeats of table readout. 0=infinite                                                                                                                       | 15:0  | R/W |
| 0x1C | Ch A number of burst repetitions                                                                                                                                     |       |     |
|      | Reserved                                                                                                                                                             | 31:16 | R   |
|      | Number of repetitions. 0=disabled                                                                                                                                    | 15:0  | R/W |
| 0x20 | Ch A delay between burst repetitions                                                                                                                                 |       |     |
|      | Delay between repetitions. Granularity=1us                                                                                                                           | 31:0  | R/W |
| 0x24 | Ch B amplitude scale and offset                                                                                                                                      |       |     |
|      | out = $\frac{\text{data*scale}}{0x2000} + \text{offset}$                                                                                                             |       |     |
|      | Reserved                                                                                                                                                             | 31:30 | R   |
|      | Amplitude offset                                                                                                                                                     | 29:16 | R/W |
|      | Reserved                                                                                                                                                             | 15:14 | R   |
|      | Amplitude scale. 0x2000 == multiply by 1. Unsigned                                                                                                                   | 13:0  | R/W |
| 0x28 | Ch B counter wrap                                                                                                                                                    |       |     |
|      | Reserved                                                                                                                                                             | 31:30 | R   |
|      | Value where counter wraps around. Depends on SM wrap setting. If it is 1 new value is get by wrap, if value is 0 counter goes to offset value. 16 bits for decimals. | 29:0  | R/W |
| 0x2C | Ch B start offset                                                                                                                                                    |       |     |
|      | Reserved                                                                                                                                                             | 31:30 | R   |
|      | Counter start offset. Start offset when trigger arrives. 16 bits for decimals.                                                                                       | 29:0  | R/W |
| 0x30 | Ch B counter step                                                                                                                                                    |       |     |
|      | Reserved                                                                                                                                                             | 31:30 | R   |
|      | Counter step. 16 bits for decimals.                                                                                                                                  | 29:0  | R/W |
| 0x34 | Ch B buffer current read pointer                                                                                                                                     |       |     |
|      | Reserved                                                                                                                                                             | 31:16 | R   |
|      | Read pointer                                                                                                                                                         | 15:2  | R/W |
|      | Reserved                                                                                                                                                             | 1:0   | R   |
| 0x38 | Ch B number of read cycles in one burst                                                                                                                              |       |     |

|                          | Reserved                                       | 31:16 | R   |
|--------------------------|------------------------------------------------|-------|-----|
|                          | Number of repeats of table readout. 0=infinite | 15:0  | R/W |
| 0x3C                     | Ch B number of burst repetitions               |       |     |
|                          | Reserved                                       | 31:16 | R   |
|                          | Number of repetitions. 0=disabled              | 15:0  | R/W |
| 0x40                     | Ch B delay between burst repetitions           |       |     |
|                          | Delay between repetitions. Granularity=1us     | 31:0  | R/W |
| 0x10000<br>to<br>0x1FFFC | Ch A memory data (16k samples)                 |       |     |
|                          | Reserved                                       | 31:14 | R   |
|                          | ch A data                                      | 13:0  | R/W |
| 0x20000<br>to<br>0x2FFFC | Ch B memory data (16k samples)                 |       |     |
|                          | Reserved                                       | 31:14 | R   |
|                          | ch B data                                      | 13:0  | R/W |

#### **PID Controller**

| offset | description                    | bits  | R/W |
|--------|--------------------------------|-------|-----|
| 0x0    | Configuration                  |       |     |
|        | Reserved                       | 31:4  | R   |
|        | PID22 integrator reset         | 3     | R/W |
|        | PID21 integrator reset         | 2     | R/W |
|        | PID12 integrator reset         | 1     | R/W |
|        | PID11 integrator reset         | 0     | R/W |
| 0x10   | PID11 set point                |       |     |
|        | Reserved                       | 31:14 | R   |
|        | PID11 set point                | 13:0  | R/W |
| 0x14   | PID11 proportional coefficient |       |     |
|        | Reserved                       | 31:14 | R   |
|        | PID11 Kp                       | 13:0  | R/W |
| 0x18   | PID11 integral coefficient     |       |     |
|        | Reserved                       | 31:14 | R   |
|        | PID11 Ki                       | 13:0  | R/W |
| 0x1C   | PID11 derivative coefficient   |       |     |
|        | Reserved                       | 31:14 | R   |
|        | PID11 Kd                       | 13:0  | R/W |
| 0x20   | PID12 set point                |       |     |
|        | Reserved                       | 31:14 | R   |
|        | PID12 set point                | 13:0  | R/W |
| 0x24   | PID12 proportional coefficient |       |     |
|        | Reserved                       | 31:14 | R   |
|        | PID12 Kp                       | 13:0  | R/W |
| 0x28   | PID12 integral coefficient     |       |     |
|        | Reserved                       | 31:14 | R   |
|        | PID12 Ki                       | 13:0  | R/W |
| 0x2C   | PID12 derivative coefficient   |       |     |
|        | Reserved                       | 31:14 | R   |
|        | PID12 Kd                       | 13:0  | R/W |
| 0x30   | PID21 set point                |       |     |
|        | Reserved                       | 31:14 | R   |
|        | PID21 set point                | 13:0  | R/W |

| 0x34 | PID21 proportional coefficient |       |     |
|------|--------------------------------|-------|-----|
|      | Reserved                       | 31:14 | R   |
|      | PID21 Kp                       | 13:0  | R/W |
| 0x38 | PID21 integral coefficient     |       |     |
|      | Reserved                       | 31:14 | R   |
|      | PID21 Ki                       | 13:0  | R/W |
| 0x3C | PID21 derivative coefficient   |       |     |
|      | Reserved                       | 31:14 | R   |
|      | PID21 Kd                       | 13:0  | R/W |
| 0x40 | PID22 set point                |       |     |
|      | Reserved                       | 31:14 | R   |
|      | PID22 set point                | 13:0  | R/W |
| 0x44 | PID22 proportional coefficient |       |     |
|      | Reserved                       | 31:14 | R   |
|      | PID22 Kp                       | 13:0  | R/W |
| 0x48 | PID22 integral coefficient     |       |     |
|      | Reserved                       | 31:14 | R   |
|      | PID22 Ki                       | 13:0  | R/W |
| 0x4C | PID22 derivative coefficient   |       |     |
|      | Reserved                       | 31:14 | R   |
|      | PID22 Kd                       | 13:0  | R/W |

# Analog Mixed Signals (AMS)

| offset | description                                          | bits  | R/W |
|--------|------------------------------------------------------|-------|-----|
| 0x0    | XADC AIF0                                            |       |     |
|        | Reserved                                             | 31:12 | R   |
|        | AIF0 value                                           | 11:0  | R   |
| 0x4    | XADC AIF1                                            |       |     |
|        | Reserved                                             | 31:12 | R   |
|        | AIF1 value                                           | 11:0  | R   |
| 0x8    | XADC AIF2                                            |       |     |
|        | Reserved                                             | 31:12 | R   |
|        | AIF2 value                                           | 11:0  | R   |
| 0xC    | XADC AIF3                                            |       |     |
|        | Reserved                                             | 31:12 | R   |
|        | AIF3 value                                           | 11:0  | R   |
| 0x10   | XADC AIF4                                            |       |     |
|        | Reserved                                             | 31:12 | R   |
|        | AIF4 value (5V power supply)                         | 11:0  | R   |
| 0x20   | PWM DAC0                                             |       |     |
|        | Reserved                                             | 31:24 | R   |
|        | PWM value (100% == 156)                              | 23:16 | R/W |
|        | Bit select for PWM repetition which have value PWM+1 | 15:0  | R/W |
| 0x24   | PWM DAC1                                             |       |     |
|        | Reserved                                             | 31:24 | R   |
|        | PWM value (100% == 156)                              | 23:16 | R/W |
|        | Bit select for PWM repetition which have value PWM+1 | 15:0  | R/W |
| 0x28   | PWM DAC2                                             |       |     |
|        | Reserved                                             | 31:24 | R   |
|        | PWM value (100% == 156)                              | 23:16 | R/W |
|        | Bit select for PWM repetition which have value PWM+1 | 15:0  | R/W |
| 0x2C   | PWM DAC3                                             |       |     |
|        | Reserved                                             | 31:24 | R   |
|        | PWM value (100% == 156)                              | 23:16 | R/W |
|        | Bit select for PWM repetition which have value PWM+1 | 15:0  | R/W |

#### RadioBox (RB)

| offset | description                                                                                                                                                                             | bits  | R/W |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----|
| 0x0    | RB_CTRL<br>Control register                                                                                                                                                             |       |     |
|        | Reserved                                                                                                                                                                                | 31:21 | R   |
|        | AMP_RF_Q_EN '1' enables the CAR_QMIX Q path for the SSB modulation.                                                                                                                     | 20    | R/W |
|        | Reserved                                                                                                                                                                                | 19:15 | R   |
|        | MOD_OSC OFS SRC STREAM  '1' places input MUXer for MOD_OSC DDS offset input to the second streamed input pipe.  '0' places MUXer to registers "MOD_OSC OFS HI" and "MOD_OSC OFS LO".    | 14    | R/W |
|        | MOD_OSC INC SRC STREAM  '1' places input MUXer for MOD_OSC DDS increment input to the second streamed input pipe.  '0' places MUXer to registers "MOD_OSC INC HI" and "MOD_OSC INC LO". | 13    | R/W |
|        | MOD_OSC RESYNC  '1' stops incrementing the accumulating phase register. That holds the oscillator just there, where it is.  With '0' the CAR_OSC resumes operation.                     | 12    | R/V |
|        | Reserved                                                                                                                                                                                | 11:7  | R   |
|        | CAR_OSC OFS SRC STREAM  '1' places input MUXer for CAR_OSC DDS offset input to the first streamed input pipe.  '0' places MUXer to registers "CAR_OSC OFS HI" and "CAR_OSC OFS LO".     | 6     | R/W |
|        | CAR_OSC INC SRC STREAM  '1' places input MUXer for CAR_OSC DDS increment input to the first streamed input pipe.  '0' places MUXer to registers "CAR_OSC INC HI" and "CAR_OSC INC LO".  | 5     | R/W |
|        | CAR_OSC RESYNC '1' stops incrementing the accumulating phase register. That holds the oscillator just there, where it is. With '0' the CAR_OSC resumes operation.                       | 4     | R/W |
|        | Reserved                                                                                                                                                                                | 3     | R   |
|        | RESET MOD_OSC  '1' resets the MOD_OSC (modulation oscillator) to its initial state like the accumulating phase register.                                                                | 2     | R/W |
|        | RESET CAR_OSC  '1' resets the CAR_OSC (carrier oscillator) to its initial state like the accumulating phase register.                                                                   | 1     | R/V |

|     | ENABLE '1' enables the RadioBox sub-module. DDS-Oscillators, multipliers, LED handling are turned on. The DAC and LEDs are connected to this sub-module when enabled. | 0     | R/W |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----|
| 0x4 | RB_STATUS<br>Status register                                                                                                                                          |       |     |
|     | STAT_LED7_ON '1' RadioBox LED7 driver that is shown at the diodes, when STAT_LEDS_EN is '1'.                                                                          | 31    | R/W |
|     | STAT_LED6_ON '1' RadioBox LED6 driver that is shown at the diodes, when STAT_LEDS_EN is '1'.                                                                          | 30    | R/W |
|     | STAT_LED5_ON '1' RadioBox LED5 driver that is shown at the diodes, when STAT_LEDS_EN is '1'.                                                                          | 29    | R/V |
|     | STAT_LED4_ON '1' RadioBox LED4 driver that is shown at the diodes, when STAT_LEDS_EN is '1'.                                                                          | 28    | R/V |
|     | STAT_LED3_ON '1' RadioBox LED3 driver that is shown at the diodes, when STAT_LEDS_EN is '1'.                                                                          | 27    | R/V |
|     | STAT_LED2_ON '1' RadioBox LED2 driver that is shown at the diodes, when STAT_LEDS_EN is '1'.                                                                          | 26    | R/V |
|     | STAT_LED1_ON '1' RadioBox LED1 driver that is shown at the diodes, when STAT_LEDS_EN is '1'.                                                                          | 25    | R/V |
|     | STAT_LED0_ON '1' RadioBox LED0 driver that is shown at the diodes, when STAT_LEDS_EN is '1'.                                                                          | 24    | R/V |
|     | Reserved                                                                                                                                                              | 23:10 | R   |
|     | STAT_MOD_OSC_VALID  '1' MOD_OSC output is valid. After turning this sub-module active it needs some clocks going into valid state.                                    | 9     | R/V |
|     | STAT_MOD_OSC_ZERO '1' MOD_OSC output equals zero. This state is based on the output of the DDS oscillator itself.                                                     | 8     | R/V |
|     | Reserved                                                                                                                                                              | 7:6   | R   |
|     | STAT_CAR_OSC_VALID  '1' CAR_OSC output is valid. After turning this sub-module active it needs some clocks going into valid state.                                    | 5     | R/V |
|     | STAT_CAR_OSC_ZERO '1' CAR_OSC output equals zero. This state is based on the output of the DDS oscillator itself.                                                     | 4     | R/V |
|     | Reserved                                                                                                                                                              | 3     | R   |

|      | STAT_LEDS_EN '1' RadioBox LEDs state is shown at the diodes, any other output register is discarded.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 2     | R/W |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----|
|      | STAT_RESET '1' reset of the RadioBox sub-system is active (clears phase accumulators).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1     | R/W |
|      | STAT_CLK_EN '1' clock of the RadioBox sub-system is enabled (power up sub-module).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0     | R/W |
| 0x8  | RB_ICR<br>Interrupt control register (reserved)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |     |
|      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 31:0  | R   |
| 0xC  | RB_ICR<br>Interrupt status register (reserved)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |     |
|      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 31:0  | R   |
| 0x10 | RB_DMA_CTRL DMA control register (reserved)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |     |
|      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 31:0  | R   |
| 0x1C | RB_SRC_CON_PNT output connection matrix for RB_LEDs, RFOUT1 and RFOUT2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |     |
|      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 31:30 | R   |
|      | 0-silence 1-silence 4-ADC selector input 5-modulation amplifier input 6-modulation amplifier output 8-MOD_QMIX I output at stage 1 9-MOD_QMIX Q output at stage 2 11-MOD_QMIX Q output at stage 2 11-MOD_QMIX Q output at stage 2 12-MOD_QMIX I output at stage 3 13-MOD_QMIX Q output at stage 3 16-LowPass MOD_CIC I output 17-LowPass MOD_CIC Q output 18-signal forming MOD_FIR I output 19-signal forming MOD_FIR Q output 20-interpolator CAR_CIC I output 41.664 MHz 21-interpolator CAR_CIC Q output 22-CAR_QMIX I output 25-CAR_QMIX Q output 28-AMP_RF output 63-test vector as signal, look for current assignments within the red pitaya radiobox.sv file |       |     |
|      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 23:22 | R   |

|      | RF Output 1 (SMA) source position: 0-silence                                                         | 21:16 | R/W |
|------|------------------------------------------------------------------------------------------------------|-------|-----|
|      |                                                                                                      |       |     |
|      | 1-silence                                                                                            |       |     |
|      | 4-ADC selector input                                                                                 |       |     |
|      | 5-modulation amplifier input                                                                         |       |     |
|      | 6-modulation amplifier output                                                                        |       |     |
|      | 8-MOD_QMIX I output at stage 1                                                                       |       |     |
|      | 9-MOD_QMIX Q output at stage 1                                                                       |       |     |
|      | 10-MOD_QMIX I output at stage 2                                                                      |       |     |
|      | 11-MOD_QMIX Q output at stage 2<br>12-MOD_QMIX I output at stage 3                                   |       |     |
|      | 13-MOD QMIX Q output at stage 3                                                                      |       |     |
|      | 16-LowPass MOD CIC I output                                                                          |       |     |
|      | 17-LowPass MOD_CIC I output 17-LowPass MOD_CIC Q output                                              |       |     |
|      | _ ` 1                                                                                                |       |     |
|      | 18-signal forming MOD_FIR I output 19-signal forming MOD_FIR Q output                                |       |     |
|      | 20-interpolator CAR CIC I output 41.664 MHz                                                          |       |     |
|      |                                                                                                      |       |     |
|      | 21-interpolator CAR_CIC Q output 41.664 MHz                                                          |       |     |
|      | 24-CAR_QMIX I output<br>25-CAR_QMIX Q output                                                         |       |     |
|      |                                                                                                      |       |     |
|      | 28-AMP_RF output                                                                                     |       |     |
|      | 63-test vector as signal, look for current assignments within the <i>red_pitaya_radiobox.sv</i> file |       |     |
|      | Reserved                                                                                             | 15:6  | R   |
|      | LEDs magnitude scope (logarithmic) source position:                                                  | 5:0   | R/V |
|      | 0-RadioBox does not touch the LED state of the other sub-module(s)                                   |       | ,   |
|      | 1-all LEDs are driven off                                                                            |       |     |
|      | 4-ADC selector input                                                                                 |       |     |
|      | 5-modulation amplifier input                                                                         |       |     |
|      | 6-modulation amplifier output                                                                        |       |     |
|      | 8-MOD QMIX I output at stage 1                                                                       |       |     |
|      | 9-MOD_QMIX Q output at stage 1                                                                       |       |     |
|      | 10-MOD QMIX I output at stage 2                                                                      |       |     |
|      | 11-MOD QMIX Q output at stage 2                                                                      |       |     |
|      | 12-MOD QMIX I output at stage 3                                                                      |       |     |
|      | 13-MOD QMIX Q output at stage 3                                                                      |       |     |
|      | 16-LowPass MOD CIC I output                                                                          |       |     |
|      | 17-LowPass MOD CIC Q output                                                                          |       |     |
|      | 18-signal forming MOD FIR I output                                                                   |       |     |
|      | 19-signal forming MOD FIR Q output                                                                   |       |     |
|      | 20-interpolator CAR CIC I output 41.664 MHz                                                          |       |     |
|      | 21-interpolator CAR CIC Q output 41.664 MHz                                                          |       |     |
|      | 24-CAR QMIX I output                                                                                 |       |     |
|      | 25-CAR QMIX Q output                                                                                 |       |     |
|      | 28-AMP RF output                                                                                     |       |     |
|      | 63-LEDs show test vector, look for current assignments within the                                    |       |     |
|      | red_pitaya_radiobox.sv file                                                                          |       |     |
| 0x20 | RB_CAR_OSC_INC_LO                                                                                    |       |     |
|      | DDS CAR_OSC, phase increment register @ 125 MHz                                                      |       |     |
|      | LSB of CAR OSC phase increment register                                                              | 31:0  | R/V |

| 0x24 | RB_CAR_OSC_INC_HI<br>DDS CAR_OSC, phase increment register @ 125 MHz |       |     |
|------|----------------------------------------------------------------------|-------|-----|
|      | Reserved                                                             | 31:16 | R   |
|      | MSB of CAR_OSC phase increment register                              | 15:0  | R/W |
| 0x28 | RB_CAR_OSC_OFS_LO DDS CAR_OSC, phase offset register @ 125 MHz       |       |     |
|      | LSB of CAR_OSC phase offset register                                 | 31:0  | R/V |
| 0x2C | RB_CAR_OSC_OFS_HI DDS CAR_OSC, phase offset register @ 125 MHz       |       |     |
|      | Reserved                                                             | 31:16 | R   |
|      | MSB of CAR_OSC phase offset register                                 | 15:0  | R/V |
| 0x30 | RB_AMP_RF_GAIN AMP RF gain register                                  |       |     |
|      | Reserved                                                             | 31:16 | R   |
|      | SIGNED 16 bit - Amplifier RF gain setting                            | 15:0  | R/V |
| 0x38 | RB_AMP_RF_OFS AMP RF offset register                                 |       |     |
|      | Reserved                                                             | 31:16 | R   |
|      | SIGNED 16 bit - Amplifier RF offset value                            | 15:0  | R/V |
| 0x40 | RB_MOD_OSC_INC_LO DDS MOD_OSC, phase increment register              |       |     |
|      | LSB of MOD_OSC phase increment register                              | 31:0  | R/V |
| 0x44 | RB_MOD_OSC_INC_HI DDS MOD_OSC, phase increment register              |       |     |
|      | Reserved                                                             | 31:16 | R   |
|      | MSB of MOD_OSC phase increment register                              | 15:0  | R/V |
| 0x48 | RB_MOD_OSC_OFS_LO DDS MOD_OSC, phase offset register                 |       |     |
|      | LSB of MOD_OSC phase offset register                                 | 31:0  | R/V |
| 0x4C | RB_MOD_OSC_OFS_HI DDS MOD_OSC, phase offset register                 |       |     |
|      | Reserved                                                             | 31:16 | R   |
|      | MSB of CAR_OSC phase offset register                                 | 15:0  | R/V |
| 0x50 | RB_MOD_QMIX_GAIN<br>MOD_QMIX gain setting (stage 2)                  |       |     |
|      | Reserved                                                             | 31:16 | R   |
|      | SIGNED 16 bit - MOD_QMIX output amplitude                            | 15:0  | R/V |
| 0x58 | RB_MOD_QMIX_OFS_LO<br>MOD_QMIX offset value (stage 3)                |       |     |
|      | LSB of MOD_QMIX offset value                                         | 15:0  | R/V |

| 0x5C | RB_MOD_QMIX_OFS_HI<br>MOD_QMIX offset value (stage 3)                                                                                                                                                                                                                                 |       |     |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----|
|      | Reserved                                                                                                                                                                                                                                                                              | 31:16 | R   |
|      | MSB of MOD_QMIX offset value                                                                                                                                                                                                                                                          | 15:0  | R/W |
| 0x60 | RB_MUXIN_SRC Source signal for the analog input MUXer                                                                                                                                                                                                                                 |       |     |
|      | Reserved                                                                                                                                                                                                                                                                              | 31:6  | R   |
|      | Source position:  0-no external signal used, MOD_OSC used instead  3-Vp_Vn, mapped to: vin[4]  16-XADC CH#0, mapped to: AI1  17-XADC CH#1, mapped to: AI0  24-XADC CH#8, mapped to: AI2  25-XADC CH#9, mapped to: AI3  32-ADC0, mapped to: RF Input 1  33-ADC1, mapped to: RF Input 2 | 5:0   | R/W |
| 0x64 | RB_MUXIN_GAIN Source signal gain for MUXIN output amplifier                                                                                                                                                                                                                           |       |     |
|      | Reserved                                                                                                                                                                                                                                                                              | 31:18 | R   |
|      | input booster – realized as left shift value: ( 7 0) gives amplification of: (128x 1x)                                                                                                                                                                                                | 18:16 | R/W |
|      | SIGNED 16 bit - MUXIN mixer amplitude                                                                                                                                                                                                                                                 | 15:0  | R/W |