

# **Communication Protocol Document**

# IF Receiver and Synthesizer (Ku-mIFRS)

Customer P/N: L3006-2300-500

Per Customer Spec.: SP-L3006-2300

| <b>Engineering Approval</b> | Date       |
|-----------------------------|------------|
| Y. Gashkalimy               | 30.10.2022 |
| <b>Customer Approval</b>    | Date       |
|                             |            |



Communication Protocol for: IF Receiver and Synthesizer (mIFRS) PN: L3006-2300-500 Ver. B 1/25



|          | Revision History |            |               |                                        |  |  |  |  |  |
|----------|------------------|------------|---------------|----------------------------------------|--|--|--|--|--|
| Revision | ECN              | Date       | Prepared by   | Description                            |  |  |  |  |  |
| A        |                  | 25.11.2021 | A. Miller     | Created                                |  |  |  |  |  |
| В        |                  | 08.09.2022 | A. Miller     | Updated according to customer requests |  |  |  |  |  |
| С        |                  | 30.10.2022 | Y. Gashkalimy | Updated communication protocol.        |  |  |  |  |  |
|          |                  |            |               |                                        |  |  |  |  |  |
|          |                  |            |               |                                        |  |  |  |  |  |
|          |                  |            |               |                                        |  |  |  |  |  |
|          |                  |            |               |                                        |  |  |  |  |  |
|          |                  |            |               |                                        |  |  |  |  |  |
|          |                  |            |               |                                        |  |  |  |  |  |
|          |                  |            |               |                                        |  |  |  |  |  |

| Communication Protocol for: IF Receiver and Synthesizer (mIFRS) PN: L3006-2300-500 | 9750303600-37 | Ver. B | 2/ 25 |  |
|------------------------------------------------------------------------------------|---------------|--------|-------|--|
|------------------------------------------------------------------------------------|---------------|--------|-------|--|



# **Table of Contents**

| 1 | Sco    | pe                                                | 4  |
|---|--------|---------------------------------------------------|----|
| 2 |        | evant Documents                                   |    |
| 3 | Cor    | nmunication Protocol                              | 5  |
|   | 3.1 In | troduction                                        | 5  |
|   | 3.2 H  | ardware Definitions                               | 5  |
|   | 3.3 Fr | ame Structure – full parameter command            | 7  |
|   |        | ming Diagram                                      |    |
|   |        | ame Structure – FPGA Set & Get registers commands |    |
|   |        | ror Codes                                         |    |
| 4 | Cor    | nmands                                            | 16 |
|   | 4.1 C  | ommands List                                      | 16 |
|   | 4.2 D  | etails Operational Command Description            | 17 |
|   | 4.2.1  |                                                   |    |
|   | 4.3 D  | etails Debug Command Description                  | 24 |
|   | 4.3.1  | Hardware Definitions                              | 24 |
|   | 4.3.2  | Serial Frame Structure                            | 25 |
|   |        |                                                   |    |
|   |        |                                                   |    |

# **List of Figures**

| Figure 1: Example for SPI Mode 0             | 5 |
|----------------------------------------------|---|
| Figure 2: Serial Communication Diagram       | 6 |
| Figure 3: Timing Diagram                     |   |
| Figure 4: SPI Serial interconnection diagram |   |

3/25



# 1 Scope

The purpose of this document is to detail the serial communication protocol used for controlling the **Ku-mIFRS System** from an Electronic Assembly (EA), including the various extensions used for simulator and system control.

# **2** Relevant Documents

• Customer Specification Documents: SP-L3006-2300

• Customer ICD Document: 9750303600-18

• Outline drawing: 9750303600-12

Communication Protocol for: IF Receiver and Synthesizer (mIFRS) PN: L3006-2300-500 Ver. B 4/ 25



### 3 Communication Protocol

### 3.1 Introduction

The host Electronic Assembly (EA) communicates with the Ku-mIFRS system through a Serial Peripheral Interface (SPI) protocol.

### 3.2 Hardware Definitions

The communication protocol between Electronic Assembly (EA) system and mIFRS system is a standard 4-wire SPI protocol, mode 0: SPI is a synchronous, full duplex master-slave-based interface.

The mIFRS system is a slave and the EA system is the master.

- SPI Clock frequency: 10MHz.
- SPI Mode 0: Clock polarity (CPOL) = 0, clock phase (CPHA) = 0: CLK idle state = low, data sampled on rising edge and shifted on falling edge.
- Dummy clock: 8 SPI Ticks.
  - o SPI Slave (mIFRS) will return ACK/NACK message after 8 SPI dummy clocks.



Figure 1: Example for SPI Mode 0

All communications will be initiated by the EA.

Communication interface description:

- Input SPI Clock (SCLK): SPI\_SCLK (LVCMOS 1.8V)
- Input SPI Chip Select (CS): SPI\_CS (LVCMOS 1.8V)
- Input SPI Master Out, Slave In (MOSI): SPI MOSI (LVCMOS 1.8V)
- Output SPI Master In, Slave Out (MISO): SPI MISO (LVCMOS 1.8V)
- Input discrete: *RF\_UPDATE* (LVDS 2.5V)
- Input discrete: TX\_PRECMD (LVDS 2.5V)
- Input discrete: *RCV\_TRIG* (LVDS 2.5V)

Communication Protocol for: IF Receiver and Synthesizer (mIFRS)
PN: L3006-2300-500
Ver. B
5/ 25





**Figure 2: Serial Communication Diagram** 

| Communication Protocol for: IF Receiver and Synthesizer (mIFRS) PN: L3006-2300-500 | 9750303600-37 | Ver. B | 6/ 25 |
|------------------------------------------------------------------------------------|---------------|--------|-------|
|------------------------------------------------------------------------------------|---------------|--------|-------|



### 3.3 Frame Structure - full parameter command

The frame is constructed from 16 header bytes then the data payload and completed with a checksum word (4 bytes).

• **Byte 0**: Preamble byte, which is Tx: 0x82, Rx: 0x83.

• Byte 1: Command opcode byte, which described in the following tables.

• Byte 2÷3: Message counter. Tx counter and Rx counter are independent,

ascending number, LSB first. RESET value is '0'

• Byte 4÷7: Length of the entire command (including the header bytes), LSB first.

• Byte 8: Command activation. all commands are triggered to one of the discrete below:

1. <u>'RF\_UPDATE' Triggered commands</u>: The response to this type of message shall be at the next start of 'RF\_UPDATE' discrete. Upon assertion of 'RF\_UPDATE' signal, the OGT shall start the process of changing RF control parameters as required by EA command. The reply to this message shall start right after the receiving command – see Figure 3.

CMD Value: 0x01

<u>'TX\_PRECEDING\_CMD'</u> Triggered commands: The response and reply to this type of message shall be at the next start of 'TX\_PRECEDING\_CMD' discrete (RF transmission pulse) – see Figure 3.

CMD Value: 0x02

<u>'RCV\_TRIGGER' Triggered commands:</u> The response and reply to this type of message shall be at the next start of 'RCV\_TRIGGER' discrete – see Figure 3.
 CMD Value: 0x04

• <u>Byte 9÷11</u>: Spare

• Byte 12÷15: Message time tag:

<u>Tx Message Time</u>: mSEM time tag

Rx Message Time: reply the mSEM time tag

Data Bytes: Payload Data,

■ Tx Data: 20 bytes long. Bytes #: 16÷35

■ Rx Data: 16 bytes long followed by 44 bytes status. Bytes #: 16÷75

**When Error** – returns checksum value, preamble and opcode values.

'Status Response' shall be sent at the end of each Rx message.

• Checksum Bytes: Checksum words (4 bytes),

Which is the result of the sum of all words (4 bytes) in the frame (unsigned).

■ <u>Tx Bytes #:</u> 36÷39, <u>Rx Bytes #:</u> 76÷79

| Communication Protocol for: IF Receiver and Synthesizer (mIFRS) PN: L3006-2300-500 | 9750303600-37 | Ver. B | 7/ 25 |
|------------------------------------------------------------------------------------|---------------|--------|-------|
|------------------------------------------------------------------------------------|---------------|--------|-------|



# Tx Frame (EA $\rightarrow$ mIFRS):

| Byte Name           | Preamble | CMD<br>Opcode | Message<br>Counter            | Message<br>Length             | CMD<br>Activation | Spare | Message<br>Time                 |
|---------------------|----------|---------------|-------------------------------|-------------------------------|-------------------|-------|---------------------------------|
| Byte<br>Number      | 0        | 1             | 2÷3<br>(LSB 1 <sup>st</sup> ) | 4÷7<br>(LSB 1 <sup>st</sup> ) | 8                 | 9÷11  | 12÷15<br>(LSB 1 <sup>st</sup> ) |
| Byte<br>Description | 0x82     | CMD           | Count                         | Length                        | Activation        | 0x00  | Time                            |

| Byte Name           |     | Check Sum |       |
|---------------------|-----|-----------|-------|
| Byte<br>Number      | 16  | <br>35    | 36÷39 |
| Byte<br>Description | TD0 | <br>TD19  | СНК   |

### Total of 40 Bytes

# Rx Frame (mIFRS $\rightarrow$ EA):

| Byte Name           | Preamble | CMD<br>Opcode | Message<br>Counter            | Message<br>Length             | CMD<br>Activation | Spare | Message<br>Time                 |
|---------------------|----------|---------------|-------------------------------|-------------------------------|-------------------|-------|---------------------------------|
| Byte Number         | 0        | 1             | 2÷3<br>(LSB 1 <sup>st</sup> ) | 4÷7<br>(LSB 1 <sup>st</sup> ) | 8                 | 9÷11  | 12÷15<br>(LSB 1 <sup>st</sup> ) |
| Byte<br>Description | 0x83     | CMD           | Count                         | Length                        | Activation        | 0x00  | Time                            |

| Byte Name           | Rx Data – zero padding not in use.<br>16 Bytes |     |      |  |  |  |
|---------------------|------------------------------------------------|-----|------|--|--|--|
| Byte Number         | 16                                             | ••• | 31   |  |  |  |
| Byte<br>Description | 0x00                                           | ••• | 0x00 |  |  |  |

| Byte Name           | Status Response (*)    | Check Sum |
|---------------------|------------------------|-----------|
| Byte Number         | 32÷75<br>44 Bytes      | 76÷79     |
| Byte<br>Description | System status response | СНК       |

- (\*) 'Status Response' shall be sent at the end of each Rx message
- (\*\*) Between two following Rx messages there will be time of at least 100 clocks without traffic on the SPI BUS

| Communication Protocol for: IF Receiver and Synthesizer (mIFRS) PN: L3006-2300-500 | 9750303600-37 | Ver. B | 8/ 25 |
|------------------------------------------------------------------------------------|---------------|--------|-------|
|------------------------------------------------------------------------------------|---------------|--------|-------|



# **Error message format:**

Rx Frame (mIFRS  $\rightarrow$  EA):

| Byte Name           | Preamble | CMD<br>Opcode | Message<br>Counter            | Message<br>Length             | CMD<br>Activation | Spare | Message<br>Time                 |
|---------------------|----------|---------------|-------------------------------|-------------------------------|-------------------|-------|---------------------------------|
| Byte Number         | 0        | 1             | 2÷3<br>(LSB 1 <sup>st</sup> ) | 4÷7<br>(LSB 1 <sup>st</sup> ) | 8                 | 9÷11  | 12÷15<br>(LSB 1 <sup>st</sup> ) |
| Byte<br>Description | 0x83     | Error code    | Count                         | Length                        | Activation        | 0x00  | Time                            |

| Byte Name           | Read<br>checksum                | Calculated checksum             | Received preamble | Received opcode | Spare –zero padding             |
|---------------------|---------------------------------|---------------------------------|-------------------|-----------------|---------------------------------|
| Byte Number         | 16÷19<br>(LSB 1 <sup>st</sup> ) | 20÷23<br>(LSB 1 <sup>st</sup> ) | 24                | 25              | 26÷31<br>(LSB 1 <sup>st</sup> ) |
| Byte<br>Description | Received checksum               | Calculated checksum             | Preamble value    | Opcode<br>value | 0x000000000000                  |

| Byte Name           | Status Response (*)    | Check Sum |
|---------------------|------------------------|-----------|
| Byte Number         | 32÷75<br>44 Bytes      | 76÷79     |
| Byte<br>Description | System status response | СНК       |

- (\*) 'Status Response' shall be sent at the end of each Rx message
- (\*\*) Between two following Rx messages there will be time of at least 100 clocks without traffic on the SPI BUS

| Communication Protocol for: IF Receiver and Synthesizer (mIFRS) PN: L3006-2300-500 | 9750303600-37 | Ver. B | 9/ 25 |
|------------------------------------------------------------------------------------|---------------|--------|-------|
|------------------------------------------------------------------------------------|---------------|--------|-------|



# 3.4 Timing Diagram



**Figure 3: Timing Diagram** 

- Minimum 'RF\_UPDATE' pulse duration is 200μSec.
- Batch is define by the time between two consecutive 'RF\_UPDATE' Pulses.
- If during RF update process, comes a requirement for generating a new Tx pulse (by TX\_PRECMD)
  - this RF pulse shall be generated, but with no guaranty for its RF substance

| Communication Protocol for: IF Receiver and Synthesizer (mIFRS) PN: L3006-2300-500 | 9750303600-37 | Ver. B | 10/ 25 |  |
|------------------------------------------------------------------------------------|---------------|--------|--------|--|
|------------------------------------------------------------------------------------|---------------|--------|--------|--|



### 3.5 Frame Structure - FPGA Set & Get registers commands

The frame is constructed from 16 bytes frame.

• **Byte 0**: Preamble byte, which is Tx: 0x82, Rx: 0x83.

• Byte 1: Command opcode byte, which described in the following tables.

0x21 – set register (write command).

0x22 – get register (read command).

• Byte 2÷3: Message counter. Ascending number, LSB first. RESET value is '0'.

• Byte 4÷7: FPGA internal registers address field, LSB first.

• Byte 8÷11: FPGA internal registers data field, LSB first.

Write command: write data value - 4 bytes, and FPGA returns

0xFFFFFEE.

**Read command**: write data value – 0x00000000 and FPGA returns the

register value – 32 bit.

■ Byte 12÷35: Zero padding, spare bytes.

• **<u>Data Bytes</u>**: Payload Data,

■ Tx Data: 20 bytes long. Bytes #:  $16 \div 35 - NA$ .

■ Rx Data: 16 bytes long followed by 44 bytes status. Bytes #: 16÷75

**When Error** – returns checksum value, preamble and opcode values.

• <u>Checksum Bytes:</u> Checksum words (4 bytes),

Which is the result of the sum of all words (4 bytes) in the frame (unsigned).

■ Tx Bytes #: 36÷39

Rx Bytes #: 76÷79

Communication Protocol for: IF Receiver and Synthesizer (mIFRS)
PN: L3006-2300-500
Ver. B
11/25

<sup>&#</sup>x27;Status Response' shall be sent at the end of each Rx message.



# **Write Command:**

# <u>Tx Frame (Host $\rightarrow$ mIFRS):</u>

| Byte Name           | Preamble | CMD<br>Opcode | Message<br>Counter            | Register Address              | Write Data                     | Zero padding                    |
|---------------------|----------|---------------|-------------------------------|-------------------------------|--------------------------------|---------------------------------|
| Byte<br>Number      | 0        | 1             | 2÷3<br>(LSB 1 <sup>st</sup> ) | 4÷7<br>(LSB 1 <sup>st</sup> ) | 8÷11<br>(LSB 1 <sup>st</sup> ) | 12÷15<br>(LSB 1 <sup>st</sup> ) |
| Byte<br>Description | 0x82     | 0x21          | Counter                       | Address – 32 bit              | Data – 32 bit                  | 0x00000000                      |

| Byte Name           | Tx Data – zero padding<br>20 Bytes |  |      | Check Sum |
|---------------------|------------------------------------|--|------|-----------|
| Byte<br>Number      | 16                                 |  | 35   | 36÷39     |
| Byte<br>Description | 0x00                               |  | 0x00 | СНК       |

# Total of 40 Bytes

# Rx Frame (mIFRS $\rightarrow$ Host):

| Byte Name           | Preamble | CMD<br>Opcode | Message<br>Counter            | Register<br>Address           | Read Data                      | Zero padding                    |
|---------------------|----------|---------------|-------------------------------|-------------------------------|--------------------------------|---------------------------------|
| Byte<br>Number      | 0        | 1             | 2÷3<br>(LSB 1 <sup>st</sup> ) | 4÷7<br>(LSB 1 <sup>st</sup> ) | 8÷11<br>(LSB 1 <sup>st</sup> ) | 12÷31<br>(LSB 1 <sup>st</sup> ) |
| Byte<br>Description | 0x83     | 0x21          | Counter                       | Address – 32<br>bit           | Return value<br>0xFFFFFEE      | 0x00000000                      |

| Byte Name           | Status Response (*)    | Check Sum |
|---------------------|------------------------|-----------|
| Byte Number         | 32÷75<br>44 Bytes      | 76÷79     |
| Byte<br>Description | System status response | СНК       |

| Communication Protocol for: IF Receiver and Synthesizer (mIFRS) PN: L3006-2300-500 | 9750303600-37 | Ver. B | 12/25 |  |
|------------------------------------------------------------------------------------|---------------|--------|-------|--|
|------------------------------------------------------------------------------------|---------------|--------|-------|--|



# **Read Command:**

# <u>Tx Frame (Host $\rightarrow$ mIFRS):</u>

| Byte Name           | Preamble | CMD<br>Opcode | Message<br>Counter            | Register<br>Address           | Write Data - NA                | Zero padding                    |
|---------------------|----------|---------------|-------------------------------|-------------------------------|--------------------------------|---------------------------------|
| Byte<br>Number      | 0        | 1             | 2÷3<br>(LSB 1 <sup>st</sup> ) | 4÷7<br>(LSB 1 <sup>st</sup> ) | 8÷11<br>(LSB 1 <sup>st</sup> ) | 12÷15<br>(LSB 1 <sup>st</sup> ) |
| Byte<br>Description | 0x82     | 0x22          | Counter                       | Address – 32<br>bit           | 0x00000000                     | 0x00000000                      |

| Byte Name           |      | Check Sum |       |
|---------------------|------|-----------|-------|
| Byte<br>Number      | 16   | <br>35    | 36÷39 |
| Byte<br>Description | 0x00 | <br>0x00  | СНК   |

# Total of 40 Bytes

# Rx Frame (mIFRS $\rightarrow$ Host):

| Byte Name           | Preamble | CMD<br>Opcode | Message<br>Counter            | Register<br>Address           | Read Data                         | Zero padding                    |
|---------------------|----------|---------------|-------------------------------|-------------------------------|-----------------------------------|---------------------------------|
| Byte<br>Number      | 0        | 1             | 2÷3<br>(LSB 1 <sup>st</sup> ) | 4÷7<br>(LSB 1 <sup>st</sup> ) | 8÷11<br>(LSB 1 <sup>st</sup> )    | 12÷15<br>(LSB 1 <sup>st</sup> ) |
| Byte<br>Description | 0x83     | 0x22          | Counter                       | Address – 32 bit              | Return register<br>value – 32 bit | 0x00000000                      |

| Byte Name           | Status Response (*)    | Check Sum |
|---------------------|------------------------|-----------|
| Byte Number         | 32÷75<br>44 Bytes      | 76÷79     |
| Byte<br>Description | System status response | СНК       |

| Communication Protocol for: IF Receiver and Synthesizer (mIFRS) PN: L3006-2300-500 | 9750303600-37 | Ver. B | 13/ 25 |  |
|------------------------------------------------------------------------------------|---------------|--------|--------|--|
|------------------------------------------------------------------------------------|---------------|--------|--------|--|



# **Error message format:**

When error message occurs FPGA will return Nack message with error code.

### Rx Frame (mIFRS $\rightarrow$ EA):

| Byte Name           | Preamble | CMD<br>Opcode | Message<br>Counter            | Message<br>Length             | CMD<br>Activation | Spare | Message<br>Time                 |
|---------------------|----------|---------------|-------------------------------|-------------------------------|-------------------|-------|---------------------------------|
| Byte Number         | 0        | 1             | 2÷3<br>(LSB 1 <sup>st</sup> ) | 4÷7<br>(LSB 1 <sup>st</sup> ) | 8                 | 9÷11  | 12÷15<br>(LSB 1 <sup>st</sup> ) |
| Byte<br>Description | 0x83     | Error code    | Count                         | Length                        | Activation        | 0x00  | Time                            |

| Byte Name           | Read<br>checksum                | Calculated checksum             | Received preamble | Received opcode | Spare –zero padding             |
|---------------------|---------------------------------|---------------------------------|-------------------|-----------------|---------------------------------|
| Byte Number         | 16÷19<br>(LSB 1 <sup>st</sup> ) | 20÷23<br>(LSB 1 <sup>st</sup> ) | 24                | 25              | 26÷31<br>(LSB 1 <sup>st</sup> ) |
| Byte<br>Description | Received checksum               | Calculated checksum             | Preamble value    | Opcode<br>value | 0x000000000000                  |

| Byte Name           | Status Response (*)    | Check Sum |
|---------------------|------------------------|-----------|
| Byte Number         | 32÷75<br>44 Bytes      | 76÷79     |
| Byte<br>Description | System status response | СНК       |

- (\*) Ack/Nack message shall be sent at the end of each Tx frame.
- (\*\*) Between two following Rx messages there will be time of at least 100 clocks without traffic on the SPI BUS.
- (\*\*\*) Error code shall be sent in Nack messages according to chapter 3.4.
- (\*\*\*\*) Error message bytes: 8, 11 to 15 holds invalid value and must be ignore

| Communication Protocol for: IF Receiver and Synthesizer (mIFRS) | 9750303600-37 | Ver. B | 14/ 25 |
|-----------------------------------------------------------------|---------------|--------|--------|
| PN: L3006-2300-500                                              | 9730303000-37 | Vel. D | 14/ 23 |



# 3.6 Error Codes

The target will return an error code in the CMD field when an error occurs.

No action will be taken if there is an error.

The following error codes supported:

| Command               | Code | Remarks                                                                           |
|-----------------------|------|-----------------------------------------------------------------------------------|
| Header error          | 0xF0 | Will return one parameter with the unidentified header                            |
| Command error         | 0xF1 | Will return one parameter with the unidentified command                           |
| Checksum error        | 0xF2 | Will return two parameters with the received checksum and the calculated checksum |
| Data error            | 0xF3 | Not implemented                                                                   |
| Execution Error       | 0xF4 | Not implemented                                                                   |
| Time-out Error type 1 | 0xF5 | FPGA, Communication timeout event.                                                |
| Time-out Error type 2 | 0xF6 |                                                                                   |
| Time-out Error type 3 | 0xF7 |                                                                                   |
| Reserved              | 0xF8 |                                                                                   |
| Reserved              | 0xF9 |                                                                                   |
| Reserved              | 0xFA |                                                                                   |
| Reserved              | 0xFB |                                                                                   |
| Reserved              | 0xFC |                                                                                   |
| Reserved              | 0xFD |                                                                                   |
| Reserved              | 0xFE |                                                                                   |
| Reserved              | 0xFF |                                                                                   |

**Table 1: Error Codes Table** 

| Communication Protocol for: IF Receiver and Synthesizer (mIFRS) PN: L3006-2300-500 | 9750303600-37 | Ver. B | 15/ 25 |  |
|------------------------------------------------------------------------------------|---------------|--------|--------|--|
|------------------------------------------------------------------------------------|---------------|--------|--------|--|



# 4 Commands

# 4.1 Commands List

| Number | Command              | Function                | Direction | Remarks |  |  |  |
|--------|----------------------|-------------------------|-----------|---------|--|--|--|
|        | Operational Commands |                         |           |         |  |  |  |
| 1.     | 0x51                 | Full Parameters Command | Write     |         |  |  |  |
|        |                      |                         |           |         |  |  |  |
|        | Error Codes          |                         |           |         |  |  |  |
| 2.     | 0xF0-0xFF            | See Table 1             |           |         |  |  |  |
|        | Debug Commands       |                         |           |         |  |  |  |
| 3.     | 0x21                 | Set FPGA Register Value | Write     |         |  |  |  |
| 4.     | 0x22                 | Get FPGA Register Value | Read      |         |  |  |  |

**Table 2: Commands List** 

| Communication Protocol for: IF Receiver and Synthesizer (mIFRS) PN: L3006-2300-500 | 9750303600-37 | Ver. B | 16/ 25 |  |
|------------------------------------------------------------------------------------|---------------|--------|--------|--|
|------------------------------------------------------------------------------------|---------------|--------|--------|--|



# **4.2 Details Operational Command Description**

### 4.2.1 Full Parameters Command

**Description:** Set all mIFRS main parameters.

Command OpCode: 0x 51

### 4.2.1.1 Full Parameters Command Tx Data

**Length:** 0x 00 28 // (40Dec)

Tx Data: See table below

### Tx Header – 16 Bytes

| Byte Name           | Preamble | CMD<br>Opcode | Message<br>Counter | Message<br>Length | CMD<br>Activation | Spare | Message Time     |
|---------------------|----------|---------------|--------------------|-------------------|-------------------|-------|------------------|
| Byte #              | 0        | 1             | 2÷3                | 4÷7               | 8                 | 9÷11  | 12÷15            |
| Byte<br>Description | 0x82     | 0x51          | Count              | 0x28              | Activation        | 0x00  | mSEM Time<br>Tag |

### Tx Data – 20 Bytes

| Byte #      | 16                                     | 17                                     | 18                       | 19                       |
|-------------|----------------------------------------|----------------------------------------|--------------------------|--------------------------|
| Description | Mask Byte #1<br>See Paragraph: 4.2.1.2 | Mask Byte #2<br>See Paragraph: 4.2.1.2 | Spare                    | System Mode              |
|             |                                        |                                        |                          |                          |
| Byte #      | 20                                     | 21                                     | 22                       | 23                       |
| Description | Reset Alarm<br>Counter                 | Spare                                  | Tx Frequency             | Tx Input Power           |
|             |                                        |                                        |                          |                          |
| Byte #      | 24                                     | 25                                     | 26                       | 27                       |
| Description | Tx Duty Cycle                          | Spare                                  | Spare                    | Rx Frequency             |
|             |                                        |                                        |                          |                          |
| Byte #      | 28                                     | 29                                     | 30                       | 31                       |
| Description | Rx CH#1<br>IF Attenuator               | Rx CH#2<br>IF Attenuator               | Rx CH#3<br>IF Attenuator | Rx CH#4<br>IF Attenuator |
|             |                                        |                                        |                          |                          |
| Byte #      | 32                                     | 33                                     | 34                       | 35                       |
| Description | Rx GRD CH<br>IF Attenuator             | Spare                                  | Spare                    | Spare                    |

### Tx Check Sum – 4 Bytes

| Byte #      | 36        | 37 | 38 | 39 |  |  |
|-------------|-----------|----|----|----|--|--|
| Description | Check Sum |    |    |    |  |  |

### **Table 3: Full Parameters Command Tx Data**

| Communication Protocol for: IF Receiver and Synthesizer (mIFRS) PN: L3006-2300-500 | 9750303600-37 | Ver. B | 17/ 25 |
|------------------------------------------------------------------------------------|---------------|--------|--------|
|------------------------------------------------------------------------------------|---------------|--------|--------|



# 4.2.1.2 Masking Bytes Description

| T4   | Command                    | Full Parameto<br>(0x01) Maskin | ers Command<br>ng Bytes Data | Message Function            | Command<br>Byte # |  |
|------|----------------------------|--------------------------------|------------------------------|-----------------------------|-------------------|--|
| Item | Name                       | Message Byte<br>Number         | Bit<br>Number                | Link                        |                   |  |
| 1.   | System Mode                |                                | Bit #7                       | System Mode Byte            | 19                |  |
| 2.   | Reset Alarm<br>Counter     |                                | Bit #6                       | Reset Alarm Counter<br>Byte | 20                |  |
| 3.   | Spare                      |                                | Bit #5                       | Spare                       | 21                |  |
| 4.   | Tx Frequency               | Duta #16                       | Bit #4                       | Tx Frequency Index Byte     | 22                |  |
| 5.   | Tx Input Power             | - Byte #16                     | Bit #3                       | Tx Power Index Byte         | 23                |  |
| 6.   | Tx Duty Cycle              |                                | Bit #2                       | Tx Duty Cycle Byte          | 24                |  |
| 7.   | Spare                      |                                | Bit #1                       | Spare                       | 25                |  |
| 8.   | Spare                      |                                | Bit #0                       | Spare                       | 26                |  |
| 9.   | Rx Frequency               |                                | Bit #7                       | Rx Frequency Index Byte     | 27                |  |
| 10.  | Rx CH#1<br>IF Attenuator   |                                | Bit #6                       | Rx Attenuators Bytes        | 28                |  |
| 11.  | Rx CH#2<br>IF Attenuator   |                                | Bit #5                       | Rx Attenuators Bytes        | 29                |  |
| 12.  | Rx CH#3<br>IF Attenuator   | D . 1117                       | Bit #4                       | Rx Attenuators Bytes        | 30                |  |
| 13.  | Rx CH#4<br>IF Attenuator   | Byte #17                       | Bit #3                       | Rx Attenuators Bytes        | 31                |  |
| 14.  | Rx GRD CH<br>IF Attenuator | ]                              | Bit #2                       | Rx Attenuators Bytes        | 32                |  |
| 15.  | Spare                      |                                | Bit #1                       | Spare                       | 33                |  |
| 16.  | Spare                      |                                | Bit #0                       | Spare                       | 34                |  |

**Table 4: Masking Bytes Description** 

| Communication Protocol for: IF Receiver and Synthesizer (mIFRS) PN: L3006-2300-500 | 9750303600-37 | Ver. B | 18/ 25 |
|------------------------------------------------------------------------------------|---------------|--------|--------|
|------------------------------------------------------------------------------------|---------------|--------|--------|

<sup>\*\*</sup> Mask bit logic: '0' – Disable, '1' – Enable



### 4.2.1.3 System Mode Byte

**Description:** Set mIFRS system mode.

Tx Data: Operational = 0 // TDD, Reset Value

Simultaneous = 1 // Tx and Rx are simultaneous

BIT = 2

Standby = 3 // TBD

### 4.2.1.4 Reset Alarm Counter Byte

**Description:** Reset all mIFRS alarm counters.

Tx Data: 0: Reset all alarm counters // Reset Value

1: Not reset

### 4.2.1.5 Tx Frequency Index Byte

**Description:** Set transmitter frequency index.

Tx Data: Index =  $0 \div 80$  // FLOW=0, FHIGH=80, Reset Value: 40

### 4.2.1.6 Tx Power Index Byte

**Description:** Set transmitter input power index.

Tx Data: Index = 0÷3, Resolution=TBD // HIGH=0, LOW=3, Reset Value: 0

### 4.2.1.7 Tx Duty Cycle Byte

**Description:** Set transmitter duty cycle.

Tx Data: Duty Cycle = 0÷35, Resolution=1% // Reset Value: 30%

### 4.2.1.8 Rx Frequency Index Byte

**Description:** Set receiver frequency index.

Tx Data: Index =  $0 \div 80$  // FLOW=0, FHIGH=80, Reset Value: 40

Communication Protocol for: IF Receiver and Synthesizer (mIFRS)
PN: L3006-2300-500
Ver. B
19/ 25



### 4.2.1.9 Rx Attenuators Bytes

**Description:** Set all receivers attenuators value.

Tx Data: Byte #28 - Channel #1 IF Attenuator

• Attenuation Value = 0÷20, Resolution=1dB // Reset Value = 0

Byte #29 - Channel #2 IF Attenuator // the same as Byte #28
Byte #30 - Channel #3 IF Attenuator // the same as Byte #28
Byte #31 - Channel #4 IF Attenuator // the same as Byte #28
Byte #32 - GRD Channel IF Attenuator // the same as Byte #28

Communication Protocol for: IF Receiver and Synthesizer (mIFRS)
PN: L3006-2300-500
Ver. B
20/ 25



### 4.2.1.10 Full Parameters Command Rx Data

**Length:** 0x 00 50 // (80Dec)

**Rx Data:** See table below

# Rx Header – 16 Bytes

| Byte Name           | Preamble | CMD<br>Opcode | Message<br>Counter | Message<br>Length | CMD<br>Activation | Spare | Message Time           |
|---------------------|----------|---------------|--------------------|-------------------|-------------------|-------|------------------------|
| Byte #              | 0        | 1             | 2÷3                | 4÷7               | 8                 | 9÷11  | 12÷15                  |
| Byte<br>Description | 0x83     | 0x51          | Count              | 0x50              | Activation        | 0x00  | Reply mSEM<br>Time Tag |

# Rx Data – 16 Bytes

| Byte #      | 16                | ••••• | ••••• | 31 |  |  |
|-------------|-------------------|-------|-------|----|--|--|
| Description | NA - Zero padding |       |       |    |  |  |

### <u>Status Response – 44 Bytes</u>

| Byte #      | 32                                 | ••••• | ••••• | 75 |  |  |  |
|-------------|------------------------------------|-------|-------|----|--|--|--|
| Description | See Paragraph 4.2.1.11: Get Status |       |       |    |  |  |  |

# Rx Check Sum – 4 Bytes

| Byte #      | 76        | 77 | 78 | 79 |  |  |
|-------------|-----------|----|----|----|--|--|
| Description | Check Sum |    |    |    |  |  |

**Table 5: Full Parameters Command Rx Data** 

| Communication Protocol for: IF Receiver and Synthesizer (mIFRS) PN: L3006-2300-500 | 9750303600-37 | Ver. B | 21/25 |  |
|------------------------------------------------------------------------------------|---------------|--------|-------|--|
|------------------------------------------------------------------------------------|---------------|--------|-------|--|



### **4.2.1.11 Get Status**

| Data                     | Byte    | Bit   | Description                                                     |
|--------------------------|---------|-------|-----------------------------------------------------------------|
|                          |         | 0     | 1 = Operational                                                 |
| mIFRS Actual System Mode |         |       | 2 = Simultaneous<br>3 = BIT                                     |
|                          |         | 1     | 4 = Standby                                                     |
|                          | 32      | 2     |                                                                 |
| Spare                    | 32      | 3 4   | '00000'                                                         |
|                          |         | 5     |                                                                 |
|                          |         | 6     | '0' - No Fail                                                   |
| mIFRS Fail               |         | 7     | $^{\circ}$ 1' - Fail (Fail = <b>OR</b> of all the failure bits) |
| Carial Name              | 33      |       | 16 bits resolution                                              |
| Serial Number            | ÷<br>34 |       | LSB=1; FS=65535                                                 |
|                          | 35      |       | Version Low: 0xLL (byte 35)                                     |
| FPGA Firmware Version    | ÷<br>36 |       | Version High: 0xHH (byte 36) Full version: HH.LL                |
|                          | 37      |       | Version Low: 0xLL (byte 37)                                     |
| FPGA Software Version    | ÷       |       | Version High: 0xHH (byte 38)                                    |
|                          | 38      |       | Full version: HH.LL                                             |
| Reserved                 | 39      |       | 0x00                                                            |
| INPUT_VOLTAGE            | 40      | [7:0] | INPUT_VOLTAGE [V] = TBD                                         |
| INPUT_CURRENT            | 41      | [7:0] | INPUT_CURRENT [mA] = TBD                                        |
| DIGITAL_3V3              | 42      | [7:0] | DIGITAL_3V3 [V] = TBD                                           |
| RF_3V8                   | 43      | [7:0] | RF_3V8 [V] = TBD                                                |
| FPGA_CORE_1V             | 44      | [7:0] | FPGA_CORE_1V [V] = TBD                                          |
| FPGA_DDR_1V35            | 45      | [7:0] | FPGA_DDR_1V35 [V] = TBD                                         |
| FPGA_AUX_1V8             | 46      | [7:0] | FPGA_AUX_1V8 [V] = TBD                                          |
| AFE79XX_0V95             | 47      | [7:0] | AFE79XX_0V95 [V] = TBD                                          |
| AFE79XX_1V2              | 48      | [7:0] | AFE79XX_1V2 [V] = TBD                                           |
| AFE79XX_1V8              | 49      | [7:0] | AFE79XX_1V8 [V] = TBD                                           |
| FPGA_TEMP                | 50      | [7:0] | FPGA_TEMP [°C] = TBD                                            |
| ADC_TEMP                 | 51      | [7:0] | ADC_TEMP [°C] = TBD                                             |

| Communication Protocol for: IF Receiver and Synthesizer (mIFRS) PN: L3006-2300-500 | 9750303600-37 | Ver. B | 22/ 25 |
|------------------------------------------------------------------------------------|---------------|--------|--------|
|------------------------------------------------------------------------------------|---------------|--------|--------|



| Data                     | Byte    | Bit     | Description                        |
|--------------------------|---------|---------|------------------------------------|
| INPUT_VOLTAGE_OV_COUNTER | 52      | [7:0]   | 8 bits                             |
| INPUT_VOLTAGE_UV_COUNTER | 53      | [7:0]   | 8 bits                             |
| INPUT_VOLTAGE_OI_COUNTER | 54      | [7:0]   | 8 bits                             |
| INPUT_VOLTAGE_UI_COUNTER | 55      | [7:0]   | 8 bits                             |
| DIGITAL_3V3_OV_COUNTER   | 56      | [7:0]   | 8 bits                             |
| DIGITAL_3V3_UV_COUNTER   | 57      | [7:0]   | 8 bits                             |
| RF_3V8_OV_COUNTER        | 58      | [7:0]   | 8 bits                             |
| RF_3V8_UV_COUNTER        | 59      | [7:0]   | 8 bits                             |
| FPGA_CORE_OV_COUNTER     | 60      | [7:0]   | 8 bits                             |
| FPGA_CORE_UV_COUNTER     | 61      | [7:0]   | 8 bits                             |
| FPGA_DDR_OV_COUNTER      | 62      | [7:0]   | 8 bits                             |
| FPGA_DDR_UV_COUNTER      | 63      | [7:0]   | 8 bits                             |
| FPGA_AUX_OV_COUNTER      | 64      | [7:0]   | 8 bits                             |
| FPGA_AUX_UV_COUNTER      | 65      | [7:0]   | 8 bits                             |
| AFE79XX_0V95_OV_COUNTER  | 66      | [7:0]   | 8 bits                             |
| AFE79XX_0V95_UV_COUNTER  | 67      | [7:0]   | 8 bits                             |
| AFE79XX_1V2_OV_COUNTER   | 68      | [7:0]   | 8 bits                             |
| AFE79XX_1V2_UV_COUNTER   | 69      | [7:0]   | 8 bits                             |
| AFE79XX_1V8_OV_COUNTER   | 70      | [7:0]   | 8 bits                             |
| AFE79XX_1V8_UV_COUNTER   | 71      | [7:0]   | 8 bits                             |
| Reserved                 | 72      | [7:0]   | 0x00                               |
|                          | 73      | F1 5 03 | 0 0 11 1                           |
| SUM_COUNTER_ALARMS       | ÷<br>74 | [15:0]  | Sum of all alarm counters, 15 bits |
| Reserved                 | 75      | [7:0]   | 0x00                               |

# **Table 6: Get Status Response**

Total Status Length: 44 bytes

| Communication Protocol for: IF Receiver and Synthesizer (mIFRS) PN: L3006-2300-500 | 9750303600-37 | Ver. B | 23/ 25 |
|------------------------------------------------------------------------------------|---------------|--------|--------|
|------------------------------------------------------------------------------------|---------------|--------|--------|



# 4.3 Details Debug Command Description

### 4.3.1 Hardware Definitions

The communication protocol between PC and simulator system is a standard UART. All communications will be initiated by the master.



Figure 4: SPI Serial interconnection diagram

| Communication Protocol for: IF Receiver and Synthesizer (mIFRS) PN: L3006-2300-500 | 9750303600-37 | Ver. B | 24/ 25 |  |
|------------------------------------------------------------------------------------|---------------|--------|--------|--|
|------------------------------------------------------------------------------------|---------------|--------|--------|--|



### 4.3.2 Serial Frame Structure

### **UART Over micro USB**





- Start bit 1
- Data bits 8 (lsb sent first).
- Parity bit 1 even parity bit.
- Stop bit -1 bit.
- Speed 115200 bps.

| Communication Protocol for: IF Receiver and Synthesizer (mIFRS) PN: L3006-2300-500 | 9750303600-37 | Ver. B | 25/ 25 |  |
|------------------------------------------------------------------------------------|---------------|--------|--------|--|
|------------------------------------------------------------------------------------|---------------|--------|--------|--|