# Pluto\_MSK\_Modem address map

Absolute Address: 0x0Base Offset: 0x0Size: 0x43C00090

| Offset     | Identifier     | Name                |
|------------|----------------|---------------------|
| 0x43C00000 | pluto_msk_regs | Pluto MSK Registers |

# pluto\_msk\_regs address map

Absolute Address: 0x43C00000Base Offset: 0x43C00000

• Size: 0x90

MSK Modem Configuration and Status Registers

| Offset | Identifier       | Name                                                 |
|--------|------------------|------------------------------------------------------|
| 0x00   | Hash_ID_Low      | Pluto MSK FPGA Hash ID - Lower 32-bits               |
| 0x04   | Hash_ID_High     | Pluto MSK FPGA Hash ID - Upper 32-bits               |
| 0x08   | $MSK\_Init$      | MSK Modem Control 0                                  |
| 0x0C   | $MSK\_Control$   | MSK Modem Control 1                                  |
| 0x10   | $MSK\_Status$    | MSK Modem Status 0                                   |
| 0x14   | $Tx\_Bit\_Count$ | MSK Modem Status 1                                   |
| 0x18   | Tx_Enable_Cou    | ntMSK Modem Status 2                                 |
| 0x1C   | $Fb\_FreqWord$   | Bitrate NCO Frequency Control Word                   |
| 0x20   | TX_F1_FreqWo     | rdIx F1 NCO Frequency Control Word                   |
| 0x24   | TX_F2_FreqWo     | rdIx F2 NCO Frequency Control Word                   |
| 0x28   | RX_F1_FreqWo     | rdx F1 NCO Frequency Control Word                    |
| 0x2C   | RX_F2_FreqWo     | rdx F2 NCO Frequency Control Word                    |
| 0x30   | LPF_Config_0     | PI Controller Configuration and Low-pass Filter      |
|        |                  | Configuration                                        |
| 0x34   | LPF_Config_1     | PI Controller Configuration Configuration Register 1 |
| 0x38   | Tx_Data_Width    | Modem Tx Input Data Width                            |
| 0x3C   |                  | Modem Rx Output Data Width                           |
| 0x40   | _                | PRBS Control 0                                       |
| 0x44   |                  | caPRBS Control 1                                     |
| 0x48   | _ ·              | aPRBS Control 2                                      |
| 0x4C   |                  | asRRBS Control 3                                     |
| 0x50   | PRBS_Bit_Cour    |                                                      |
| 0x54   | PRBS_Error_Co    | Oul PRBS Status 1                                    |
| 0x58   |                  | F1 PI Controller Accumulator                         |
| 0x5C   |                  | F2 PI Controller Accumulator                         |
| 0x60   |                  | MSK Modem Status 3                                   |
| 0x64   | Rx_Sample_Disc   | called Sample Discard                                |

| Offset | Identifier       | Name                                                 |
|--------|------------------|------------------------------------------------------|
| 0x68   | LPF_Config_2     | PI Controller Configuration Configuration Register 2 |
| 0x6C   | f1_nco_adjust    | F1 NCO Frequency Adjust                              |
| 0x70   | f2_nco_adjust    | F2 NCO Frequency Adjust                              |
| 0x74   | f1_error         | F1 Error Value                                       |
| 0x78   | f2_error         | F2 Error Value                                       |
| 0x7C   | $Tx\_Sync\_Ctrl$ | Transmitter Sync Control                             |
| 0x80   | $Tx\_Sync\_Cnt$  | Transmitter Sync Duration                            |
| 0x84   | lowpass_ema_alp  | olfatponential Moving Average Alpha                  |
| 0x88   | lowpass_ema_alp  | olæ⊋ponential Moving Average Alpha                   |
| 0x8C   | $rx\_power$      | Receive Power                                        |

## Hash\_ID\_Low register

• Absolute Address: 0x43C00000

• Base Offset: 0x0

• Size: 0x4

| Bits | Identifier     | Access | Reset      | Name                  |
|------|----------------|--------|------------|-----------------------|
| 31:0 | $hash\_id\_lo$ | r      | 0xAAAA5555 | Hash ID Lower 32-bits |

hash\_id\_lo field Lower 32-bits of Pluto MSK FPGA Hash ID

## Hash\_ID\_High register

• Absolute Address: 0x43C00004

• Base Offset: 0x4

• Size: 0x4

| Bits | Identifier | Access | Reset      | Name                  |
|------|------------|--------|------------|-----------------------|
| 31:0 | hash_id_hi | r      | 0x5555AAAA | Hash ID Upper 32-bits |

hash\_id\_hi field Upper 32-bits of Pluto MSK FPGA Hash ID

## MSK\_Init register

• Absolute Address: 0x43C00008

• Base Offset: 0x8

• Size: 0x4

Synchronous initialization of MSK Modem functions, does not affect configuration registers.

| Bits | Identifier | Access | Reset | Name              |
|------|------------|--------|-------|-------------------|
| 0    | txrxinit   | rw     | 0x1   | Tx/Rx Init Enable |
| 1    | txinit     | rw     | 0x1   | Tx Init Enable    |
| 2    | rxinit     | rw     | 0x1   | Rx Init Enable    |

txrxinit field 0-> Normal modem operation 1-> Initialize Tx and Rx

txinit field  $0 \rightarrow Normal Tx operation <math>1 \rightarrow Initialize Tx$ 

**rxinit field**  $0 \rightarrow Normal Rx operation <math>1 \rightarrow Initialize Rx$ 

#### MSK\_Control register

• Absolute Address: 0x43C0000C

• Base Offset: 0xC

• Size: 0x4

MSK Modem Configuration and Control

| Bits | Identifier                | Access   | Reset      | Name                                           |
|------|---------------------------|----------|------------|------------------------------------------------|
| 0    | ptt                       | rw       | 0x0        | Push-to-Talk Enable                            |
| 2    | loopback_ena<br>rx_invert | rw<br>rw | 0x0<br>0x0 | Modem Loopback Enable<br>Rx Data Invert Enable |
| 3    | $clear\_counts$           | rw       | 0x0        | Clear Status Counters                          |

**ptt field**  $0 \rightarrow PTT$  Disabled  $1 \rightarrow PTT$  Enabled

 ${\bf loopback\_ena}$ field  $\ 0 -> {\bf Modem}$ loopback disabled 1 ->  ${\bf Modem}$ loopback enabled

 $\mathbf{rx}$ \_invert field 0 -> Rx data normal 1 -> Rx data inverted

clear\_counts field Clear Tx Bit Counter and Tx Enable Counter

#### MSK\_Status register

• Absolute Address: 0x43C00010

• Base Offset: 0x10

• Size: 0x4

Modem status bits

| Bits | Identifier    | Access       | Reset | Name                                 |
|------|---------------|--------------|-------|--------------------------------------|
| 0    | demod_sync_le | oak          | 0x0   | Demodulator Sync Status              |
| 1    | $tx_enable$   | $\mathbf{r}$ | 0x0   | AD9363 DAC Interface Tx Enable Input |
|      |               |              |       | Active                               |
| 2    | $rx_enable$   | r            | 0x0   | AD9363 ADC Interface Rx Enable Input |
|      |               |              |       | Active                               |
| 3    | tx_axis_valid | r            | 0x0   | Tx S_AXIS_VALID                      |

 ${\bf demod\_sync\_lock\ field} \quad {\bf Demodulator\ Sync\ Status\ -\ not\ currently\ implemented}$ 

tx\_enable field 1-> Data to DAC Enabled 0-> Data to DAC Disabled

**rx\_enable field** 1 -> Data from ADC Enabled 0 -> Data from ADC Disabled

 ${\bf tx\_axis\_valid}$  field ~1 -> S\_AXIS\_VALID Enabled 0 -> S\_AXIS\_VALID Disabled

# $Tx\_Bit\_Count register$

• Absolute Address: 0x43C00014

• Base Offset: 0x14

• Size: 0x4

Modem status data

| Bits | Identifier         | Access | Reset | Name         |
|------|--------------------|--------|-------|--------------|
| 31:0 | $tx\_bit\_counter$ | r      | 0x0   | Tx Bit Count |

# ${\bf Tx\_Enable\_Count\ register}$

• Absolute Address: 0x43C00018

• Base Offset: 0x18

• Size: 0x4

Modem status data

| Bits | Identifier     | Access | Reset | Name            |
|------|----------------|--------|-------|-----------------|
| 31:0 | tx_ena_counter | r      | 0x0   | Tx Enable Count |

tx\_ena\_counter field Number of clocks on which Tx Enable is active

## Fb\_FreqWord register

• Absolute Address: 0x43C0001C

• Base Offset: 0x1C

• Size: 0x4

Set Modem Data Rate

| Bits | Identifier     | Access | Reset | Name                   |
|------|----------------|--------|-------|------------------------|
| 31:0 | $config\_data$ | rw     | 0x0   | Frequency Control Word |

**config\_data field** Sets the center frequency of the NCO as  $FW = Fn * 2^32/Fs$ , where Fn is the desired NCO frequency, and Fs is the NCO sample rate

#### $TX_F1_FreqWord\ register$

• Absolute Address: 0x43C00020

• Base Offset: 0x20

• Size: 0x4

Set Modulator F1 Frequency

| Bits | Identifier     | Access | Reset | Name                   |
|------|----------------|--------|-------|------------------------|
| 31:0 | $config\_data$ | rw     | 0x0   | Frequency Control Word |

**config\_data field** Sets the center frequency of the NCO as FW = Fn  $^*$  2^32/Fs, where Fn is the desired NCO frequency, and Fs is the NCO sample rate

## $TX\_F2\_FreqWord\ register$

• Absolute Address: 0x43C00024

• Base Offset: 0x24

• Size: 0x4

Set Modulator F2 Frequency

| Bits | Identifier  | Access | Reset | Name                   |
|------|-------------|--------|-------|------------------------|
| 31:0 | config_data | rw     | 0x0   | Frequency Control Word |

**config\_data field** Sets the center frequency of the NCO as FW = Fn  $^*$   $2^32/Fs$ , where Fn is the desired NCO frequency, and Fs is the NCO sample rate

## $RX_F1_FreqWord$ register

• Absolute Address: 0x43C00028

• Base Offset: 0x28

• Size: 0x4

Set Demodulator F1 Frequency

| Bits | Identifier     | Access | Reset | Name                   |
|------|----------------|--------|-------|------------------------|
| 31:0 | $config\_data$ | rw     | 0x0   | Frequency Control Word |

**config\_data field** Sets the center frequency of the NCO as FW = Fn  $^*$  2^32/Fs, where Fn is the desired NCO frequency, and Fs is the NCO sample rate

## $RX_F2_FreqWord$ register

• Absolute Address: 0x43C0002C

• Base Offset: 0x2C

• Size: 0x4

Set Demodulator F2 Frequency

| Bits | Identifier  | Access | Reset | Name                   |
|------|-------------|--------|-------|------------------------|
| 31:0 | config_data | rw     | 0x0   | Frequency Control Word |

**config\_data field** Sets the center frequency of the NCO as FW = Fn  $^*$   $2^32/Fs$ , where Fn is the desired NCO frequency, and Fs is the NCO sample rate

#### LPF\_Config\_0 register

• Absolute Address: 0x43C00030

• Base Offset: 0x30

• Size: 0x4

Configure PI controller and low-pass filter

| Bits | Identifier       | Access | Reset | Name                                   |
|------|------------------|--------|-------|----------------------------------------|
| 0    | lpf_freeze       | rw     | 0x0   | Freeze the accumulator's current value |
| 1    | $lpf\_zero$      | rw     | 0x0   | Hold the PI Accumulator at zero        |
| 7:2  | $prbs\_reserved$ | W      | 0x0   | _                                      |
| 31:8 | lpf_alpha        | rw     | 0x0   | Lowpass IIR filter alpha               |

 $lpf\_freeze field 0 -> Normal operation 1 -> Freeze current value$ 

 $lpf\_zero\ field\ 0 \rightarrow Normal\ operation\ 1 \rightarrow Zero\ and\ hold\ accumulator$ 

lpf\_alpha field Value controls the filter rolloff

## LPF\_Config\_1 register

• Absolute Address: 0x43C00034

• Base Offset: 0x34

• Size: 0x4

Configures PI Controller I-gain and divisor

| Bits  | Identifier | Access | Reset | Name                    |
|-------|------------|--------|-------|-------------------------|
| 23:0  | i_gain     | rw     | 0x0   | Integral Gain Value     |
| 31:24 | i_shift    | rw     | 0x0   | Integral Gain Bit Shift |

i\_gain field Value m of 0-16,777,215 sets the integral multiplier

i\_shift field Value n of 0-32 sets the integral divisor as 2^-n

#### $Tx\_Data\_Width register$

• Absolute Address: 0x43C00038

• Base Offset: 0x38

• Size: 0x4

Set the parallel data width of the parallel-to-serial converter

| Bits | Identifier    | Access | Reset | Name                          |
|------|---------------|--------|-------|-------------------------------|
| 7:0  | $data\_width$ | rw     | 0x8   | Modem input/output data width |

data\_width field Set the data width of the modem input/output

#### Rx\_Data\_Width register

• Absolute Address: 0x43C0003C

• Base Offset: 0x3C

• Size: 0x4

Set the parallel data width of the serial-to-parallel converter

| Bits | Identifier | Access | Reset | Name                          |
|------|------------|--------|-------|-------------------------------|
| 7:0  | data_width | rw     | 0x8   | Modem input/output data width |

data\_width field Set the data width of the modem input/output

#### PRBS\_Control register

• Absolute Address: 0x43C00040

• Base Offset: 0x40

• Size: 0x4

Configures operation of the PRBS Generator and Monitor

| Bits  | Identifier              | Access | Reset | Name                     |
|-------|-------------------------|--------|-------|--------------------------|
| 0     | prbs_sel                | rw     | 0x0   | PRBS Data Select         |
| 1     | $prbs\_error\_insert$   | W      | 0x0   | PRBS Error Insert        |
| 2     | $prbs\_clear$           | W      | 0x0   | PRBS Clear Counters      |
| 3     | prbs_manual_sync        | W      | 0x0   | PRBS Manual Sync         |
| 15:4  | $prbs\_reserved$        | W      | 0x0   | _                        |
| 31:16 | $prbs\_sync\_threshold$ | W      | 0x0   | PRBS Auto Sync Threshold |

 $prbs\_sel field 0 -> Select Normal Tx Data 1 -> Select PRBS Tx Data$ 

<code>prbs\_error\_insert field</code>  $0 \rightarrow 1$ : Insert bit error in Tx data (both Normal and PRBS)  $1 \rightarrow 0$ : Insert bit error in Tx data (both Normal and PRBS)

prbs\_clear field  $0 \rightarrow 1$ : Clear PRBS Counters  $1 \rightarrow 0$ : Clear PRBS Counters

prbs\_manual\_sync field  $0 \rightarrow 1$ : Synchronize PRBS monitor  $1 \rightarrow 0$ : Synchronize PRBS monitor

 ${\bf prbs\_sync\_threshold}$  field ~0: Auto Sync Disabled N >0: Auto sync after N errors

#### ${\bf PRBS\_Initial\_State\ register}$

• Absolute Address: 0x43C00044

• Base Offset: 0x44

• Size: 0x4

PRBS Initial State

| Bits | Identifier     | Access | Reset | Name      |
|------|----------------|--------|-------|-----------|
| 31:0 | $config\_data$ | rw     | 0x0   | PRBS Seed |

config\_data field Sets the starting value of the PRBS generator

## PRBS\_Polynomial register

• Absolute Address: 0x43C00048

• Base Offset: 0x48

• Size: 0x4

## PRBS Polynomial

| Bits | Identifier     | Access | Reset | Name            |
|------|----------------|--------|-------|-----------------|
| 31:0 | $config\_data$ | rw     | 0x0   | PRBS Polynomial |

**config\_data field** Bit positions set to '1' indicate polynomial feedback positions

## PRBS\_Error\_Mask register

• Absolute Address: 0x43C0004C

• Base Offset: 0x4C

• Size: 0x4

## PRBS Error Mask

| Bits | Identifier     | Access | Reset | Name            |
|------|----------------|--------|-------|-----------------|
| 31:0 | $config\_data$ | rw     | 0x0   | PRBS Error Mask |

**config\_data field** Bit positions set to '1' indicate bits that are inverted when a bit error is inserted

## ${\bf PRBS\_Bit\_Count\ register}$

• Absolute Address: 0x43C00050

• Base Offset: 0x50

• Size: 0x4

#### PRBS Bits Received

| Bits | Identifier     | Access | Reset | Name               |
|------|----------------|--------|-------|--------------------|
| 31:0 | $status\_data$ | r      | 0x0   | PRBS Bits Received |

**status\_data field** Number of bits received by the PRBS monitor since last BER can be calculated as the ratio of received bits to errored-bits

## PRBS\_Error\_Count register

• Absolute Address: 0x43C00054

• Base Offset: 0x54

• Size: 0x4

PRBS Bit Errors

| Bits | Identifier     | Access | Reset | Name            |
|------|----------------|--------|-------|-----------------|
| 31:0 | $status\_data$ | r      | 0x0   | PRBS Bit Errors |

status\_data field Number of errored-bits received by the PRBS monitor since last sync BER can be calculated as the ratio of received bits to errored-bits

#### LPF\_Accum\_F1 register

• Absolute Address: 0x43C00058

• Base Offset: 0x58

• Size: 0x4

Value of the F1 PI Controller Accumulator

| Bits | Identifier  | Access | Reset | Name                            |
|------|-------------|--------|-------|---------------------------------|
| 31:0 | status_data | r      | 0x0   | PI Controller Accumulator Value |

status\_data field PI Controller Accumulator Value

#### LPF\_Accum\_F2 register

• Absolute Address: 0x43C0005C

• Base Offset: 0x5C

• Size: 0x4

Value of the F2 PI Controller Accumulator

| Bits | Identifier  | Access       | Reset | Name                            |
|------|-------------|--------------|-------|---------------------------------|
| 31:0 | status_data | $\mathbf{r}$ | 0x0   | PI Controller Accumulator Value |

status\_data field PI Controller Accumulator Value

#### axis\_xfer\_count register

• Absolute Address: 0x43C00060

• Base Offset: 0x60

• Size: 0x4

Modem status data

| Bits | Identifier    | Access | Reset | Name             |
|------|---------------|--------|-------|------------------|
| 31:0 | $xfer\_count$ | r      | 0x0   | S_AXIS Transfers |

xfer\_count field Number completed S\_AXIS transfers

#### Rx\_Sample\_Discard register

• Absolute Address: 0x43C00064

• Base Offset: 0x64

• Size: 0x4

Configure samples discard operation for demodulator

| Bits | Identifier        | Access | Reset | Name                        |
|------|-------------------|--------|-------|-----------------------------|
|      | rx_sample_discard | rw     | 0x0   | Rx Sample Discard Value     |
|      | rx_nco_discard    | rw     | 0x0   | Rx NCO Sample Discard Value |

rx\_sample\_discard field Number of Rx samples to discard

rx\_nco\_discard field Number of NCO samples to discard

## $LPF\_Config\_2$ register

• Absolute Address: 0x43C00068

• Base Offset: 0x68

• Size: 0x4

Configures PI Controller I-gain and divisor

| Bits  | Identifier | Access | Reset     | Name                        |
|-------|------------|--------|-----------|-----------------------------|
| 23:0  | p_gain     | rw     | 0x0 $0x0$ | Proportional Gain Value     |
| 31:24 | p_shift    | rw     |           | Proportional Gain Bit Shift |

p\_gain field Value m of 0-16,777,215 sets the proportional multiplier

**p\_shift field** Value n of 0-32 sets the proportional divisor as 2^-n

#### f1\_nco\_adjust register

• Absolute Address: 0x43C0006C

• Base Offset: 0x6C

• Size: 0x4

Frequency offet applied to the F1 NCO

| Bits | Identifier | Access | Reset | Name                    |
|------|------------|--------|-------|-------------------------|
| 31:0 | data       | r      | 0x0   | F1 NCO Frequency Adjust |

data field Frequency offet applied to the F1 NCO

# $f2\_nco\_adjust\ register$

• Absolute Address: 0x43C00070

• Base Offset: 0x70

• Size: 0x4

Frequency offet applied to the F2 NCO

| Bits | Identifier | Access | Reset | Name                    |
|------|------------|--------|-------|-------------------------|
| 31:0 | data       | r      | 0x0   | F2 NCO Frequency Adjust |

data field Frequency offet applied to the F2 NCO

#### f1\_error register

• Absolute Address: 0x43C00074

• Base Offset: 0x74

• Size: 0x4

Error value of the F1 Costas loop after each active bit period

| Bits | Identifier | Access | Reset | Name           |
|------|------------|--------|-------|----------------|
| 31:0 | data       | r      | 0x0   | F1 Error Value |

# f2\_error register

• Absolute Address: 0x43C00078

• Base Offset: 0x78

• Size: 0x4

Error value of the F2 Costas loop after each active bit period

| Bits | Identifier | Access | Reset | Name           |
|------|------------|--------|-------|----------------|
| 31:0 | data       | r      | 0x0   | F2 Error Value |

## Tx\_Sync\_Ctrl register

• Absolute Address: 0x43C0007C

• Base Offset: 0x7C

• Size: 0x4

Provides control bits for generation of transmitter synchronization patterns

| Bits | Identifier        | Access | Reset | Name              |
|------|-------------------|--------|-------|-------------------|
| 0    | tx_sync_ena       | rw     | 0x0   | Tx Sync Enable    |
| 1    | $tx\_sync\_force$ | rw     | 0x0   | Tx Sync Force     |
| 2    | $tx\_sync\_f1$    | rw     | 0x0   | Tx F1 Sync Enable |
| 3    | $tx\_sync\_f2$    | rw     | 0x0   | Tx F2 Sync Enable |

 $\mathbf{tx\_sync\_ena}$  field 0 -> Disable sync transmission 1 -> Enable sync transmission when PTT is asserted

**tx\_sync\_force field** 0 : Normal operation) 1 : Transmit synchronization pattern)

 $tx\_sync\_f1$  field Enables/Disables transmission of F1 tone for receiver synchronization 0: F1 tone transmission disabled 1: F1 tone transmission enabled Both F1 and F2 can be enabled at the same time

 $tx\_sync\_f2$  field Enables/Disables transmission of F2 tone for receiver synchronization 0: F2 tone transmission disabled 1: F2 tone transmission enabled Both F1 and F2 can be enabled at the same time

#### Tx\_Sync\_Cnt register

• Absolute Address: 0x43C00080

• Base Offset: 0x80

• Size: 0x4

Sets the duration of the synchronization tones when enabled

| Bits | Identifier  | Access | Reset | Name             |
|------|-------------|--------|-------|------------------|
| 23:0 | tx_sync_cnt | rw     | 0x0   | Tx sync duration |

**tx\_sync\_cnt field** Value from 0x00\_0000 to 0xFF\_FFFF. This value represents the number bit-times the synchronization signal should be sent after PTT is asserted.

## $lowpass\_ema\_alpha1$ register

• Absolute Address: 0x43C00084

• Base Offset: 0x84

• Size: 0x4

Sets the alpha for the EMA

| Bits | Identifier | Access | Reset | Name      |
|------|------------|--------|-------|-----------|
| 17:0 | alpha      | rw     | 0x0   | EMA alpha |

alpha field Value from 0x0\_0000 to 0x3\_FFFF represent the EMA alpha

## $lowpass\_ema\_alpha2$ register

• Absolute Address: 0x43C00088

• Base Offset: 0x88

• Size: 0x4

Sets the alpha for the EMA

| Bits | Identifier | Access | Reset | Name      |
|------|------------|--------|-------|-----------|
| 17:0 | alpha      | rw     | 0x0   | EMA alpha |

alpha field Value from 0x0 0000 to 0x3 FFFF represent the EMA alpha

## $rx\_power register$

• Absolute Address: 0x43C0008C

• Base Offset: 0x8C

• Size: 0x4

Receive power computed from I/Q samples

| Bits | Identifier | Access | Reset | Name          |
|------|------------|--------|-------|---------------|
| 22:0 | rx_power   | r      | 0x0   | Receive Power |

 ${\bf rx\_power}$  field Value that represent the RMS power of the incoming I;