

# PCI Express SDR100 Board

Version: 2025-06-13

## Table of Contents

| 1       | 1 Features                                          | $\dots\dots 1$ |
|---------|-----------------------------------------------------|----------------|
| ${f 2}$ | 2 Installation with the Amarisoft software          | 2              |
|         | 2.1 Introduction                                    |                |
|         | 2.2 Automatic Installation                          |                |
|         | 2.3 Manual Installation                             |                |
|         | 2.4 Driver initialization                           |                |
|         | 2.5 Firmware upgrade                                |                |
|         | 2.6 Multiple card installation                      | 3              |
|         | 2.7 RX Channel Mapping                              | 4              |
|         | 2.8 FR2 support                                     |                |
|         | 2.9 TDD support                                     |                |
|         | 2.10 GPS usage                                      |                |
|         | 2.11 Oscillator frequency automatic tuning from GPS |                |
|         | 2.12 Oscillator frequency fine tuning               |                |
| 3       | B TRX driver configuration options                  | 8              |
| •       | 3.1 Single card configuration                       |                |
|         | 3.2 Multiple card configuration                     |                |
|         | 5.2 Multiple card configuration                     | 10             |
| 4       | 4 Troubleshooting                                   | 11             |
| 5       | 5 Miscellaneous utilities                           | 19             |
| J       |                                                     |                |
|         | 5.1 sdr_util                                        |                |
|         | 5.3 sdr_play                                        |                |
|         | 5.4 sdr_test                                        |                |
|         | 0.1 bar=1650                                        |                |
| 6       | 6 C API                                             | 17             |
|         |                                                     |                |
| 7       | 7 Physical specifications                           | 18             |
| •       | 7.1 Summary                                         |                |
|         | 7.1 Summary 7.2 Connectors                          |                |
|         | 7.2.1 SMA connectors                                |                |
|         | 7.2.2 SATA PPS/Clock connectors                     |                |
|         | 7.2.3 UFL connectors                                |                |
|         | 7.2.4 GPIO connectors                               |                |
|         | 7.3 RX power                                        |                |
|         | 7.4 TX power                                        |                |
| _       |                                                     | 22             |
| 8       |                                                     |                |
|         | 8.1 clock_tune                                      | 22             |

| 9  | C   | Change history     | 23          |
|----|-----|--------------------|-------------|
|    | 9.1 | Version 2025-06-13 |             |
|    | 9.2 | Version 2024-06-14 |             |
|    | 9.3 | Version 2023-09-08 |             |
|    | 9.4 | Version 2023-06-10 | 23          |
| 10 | 0   | License            | $oxdot{24}$ |

## 1 Features

- Dual 2x2 RF transceiver (AD9371)
- $\bullet~$  RF coverage: 300 MHz to 6.0 GHz
- RF bandwidth: up to 100 MHz
- Supports TDD and FDD operation
- Integrated TX/RX switch for TDD operation
- PCIe 8x standard connector
- Integrated GPS for precise time and frequency synchronization
- Clock/PPS inputs and outputs for easy synchronisation
- Optional sample compression to reduce the PCI bandwidth

### 2 Installation with the Amarisoft software

#### 2.1 Introduction

If you have bought the OTS (Off-The-Shelve) package, then you dont need to install anything. Everything has already been installed on your PC. Otherwise, please follow through the steps below.

Decompress the trx\_sdr archive into a convenient directory specified by <trx\_path>.

```
tar -xzf trx_sdr-linux-YYYY-MM-DD.tar.gz -C <trx_path>
```

You have two ways to install the TRX driver for the PCIe card:

- automatic
- manual

For both cases, the installation requires some specific packages to compile the kernel module. To do this, you need to be root. In Fedora and Cent OS, you need to install *kernel-devel*, *make*, *gcc* and *elfutils-libelf-devel* packages by running the following command:

```
dnf install kernel-devel-$(uname -r) make gcc elfutils-libelf-devel
For Ubuntu, use the following command:
```

```
apt-get install $(uname -a | awk '{print $3}') build-essential
```

Note that you'll need equivalent packages for other Linux distributions if you do not use Fedora, Ubuntu or Cent OS.

Once you have finished the installation, you need to initialize (See [Driver initialization], page 3) and upgrade your driver (See [Firmware upgrade], page 3). Please make sure to initialize the driver after each system boot if you have not activates an automatic lte service.

#### 2.2 Automatic Installation

Automatic installation is only available on Fedora, Ubuntu and CentOS distributions. Use manual install for other distributions. To start your automatic install, use the following command where <path> is the path to the directory where you have already installed your LTE component (eNB or UE) and type should be set to enb or ue accordingly.

```
./install <path> <type>
```

Notes:

- the script would install some packages, so make sure you have root privileges when you run the script
- this install creates a symlink for the TRX driver so please do not remove this directory afterwards.

#### 2.3 Manual Installation

To manually install the driver, let's note <path> the directory where Amarisoft eNB or UE software is installed. Then:

1. Compile kernel driver:

Go to the kernel/ directory under <trx\_path> and start compilation:

```
cd kernel
```

2. Place driver:

Just copy the compiled driver into <path> directory

```
cd ..
```

```
cp trx_sdr.so <path>
cp libsdr.so <path>
cp libc_wrapper_sdr.so <path>
```

#### 3. Config files:

Copy RF driver config file. Note that there are 2 separate config directories for eNB and UE called config.enb and config.ue under your <trx\_path>. As a result, the <config\_dir> should be set to config.enb or config.ue accordingly.

```
cp -r <config_dir> <path>/config/sdr
Select frontend:
    <path>/config/rf_select.sh sdr
```

#### 2.4 Driver initialization

Each time you boot your system, you need to perform this initialization. Note that if you are using OTS install, this step is already done by the lte service.

```
cd kernel
./init.sh
```

## 2.5 Firmware upgrade

Perform the following command to upgrade your PCIe card:

```
./sdr_util upgrade
```

Notes:

- If you have several PCIe cards installed, this will upgrade all cards.
- If the firmware is already up to date, this command will end directly.
- When the upgrade is over, you need your system to be powered off for the changes to take effect (not only reset, real power off).

## 2.6 Multiple card installation

To make several cards work together, they must be time and frequency synchronized. For that purpose you need to plug a standard SATA cable between boards. Connect one of the three CLK\_OUT connectors on the Master board (Figure 7.1) to the CLK\_IN of the Slave board (Figure 7.1); connectors are on top of PCI boards. You can Slave up to three SDR100 boards to one SDR100 board.

Each SDR100 board is seen as two linux devices with consecutive minors. The secondary is automatically slaved to the primary for clock and PPS.

The primary device always has an even minor and the secondary has the next minor. For instance, if you install one SDR100 boards, it will appear as sdr0 and sdr1 devices

When you install several PCIe cards, the mapping between the PCI connectors and the Linux devices is not predictable (but it shouldn't change after each boot). To identify the order please do the following:

```
./sdr_util -c 0 led 1
```

Then check inside PC on each board: the leds are visible on the top edge of the SDR100. One of them should have a led blinking, this is card 0 (/dev/sdr0).

Switch off the led:

```
./sdr_util -c 0 led 0
You can do the same for other cards:
./sdr_util -c <n> led 2
```

Where <n> is the index of the card.

Remember primary and secondary (sdr0 and sdr1) will have leds placed on the same SDR100 board.

To use all the cards, update eNB config file (config.cfg) using args parameter:

```
args: "dev0=/dev/sdrA,dev1=/dev/sdrB,..."
```

Note: this allow to change the order of the cards. For instance, if your card are from left to right have following indexes:

```
<2,3> <4,5> <0,1>
```

And you want first cells to be on left, then on the middle and then on right, use the following:

```
args: "dev0=/dev/sdr2,dev1=/dev/sdr3,dev2=/dev/sdr4,dev3=/dev/sdr5,dev4=/dev/sdr0,dev5=/dev/sdr1"
```

### 2.7 RX Channel Mapping

Commercial CPEs have different antenna configurations depending on the band used. As an exemple, Telit FN980 CPE has different TX antenna mapping in bands n41 and n78 as shown in the following table:

| Antenna port | TX                                         |
|--------------|--------------------------------------------|
| ANT0         | n41 diversity antenna                      |
| ANT1         | n78 main antenna                           |
| ANT2         | n41 main antenna and n78 diversity antenna |
|              |                                            |

ANT3 No TX

Amarisoft SDR100 card has 4 RX ports: RX1, RX2, RX3 and RX4 but the main RX antenna is always considered to be RX1 by default. In case of multiple streams in UL, the RX ports are used consecutively. As an example in case of MIMO 2x2 in UL, RX1 and RX2 will be used. This static setting is not practical when testing multiple bands in conducted mode. Let's consider a cabled test with the Telit CPE FN980. In case of n78, the CPE ANT1 should be connected to the RX1 port of the SDR card while in n41, the CPE ANT2 should be connected to RX1.

In order to make the cabling easier, we have introduced a new parameter in the RF driver called rx\_chan\_mapping(See [rx\_chan\_mapping], page 8) which defines the list of physical RX ports to be used per RF port. This parameter is a string separated by , for each RF port. Inside each RF port, there is a list of physical RX port indexes that are used by each UL stream.

```
rx_chan_mapping uses the RX port index going from 0 to the number of RX ports - 1.
```

Let's take an example of a configuration with one cell MIMO 4x4 in DL and SISO in UL in n78 connected by cables to a Telit FN980 CPE with 4 antenna ports as depicted below. This

configuration can be run on one single SDR100 card.



The CPE uses ANT1 as the main antenna for UL in band 78. However, the ANT1 is connected physically to TX2/RX2 as can be seen in the above figure. Setting rx\_chan\_mapping to 1 means that the SDR driver should expect to receive the UL data on the RX2 port (the index of RX2 is one). The corresponding rf\_driver configuration is as below. There is only one single stream in UL which is mapped to RX2 and there is only one cell (one rf\_port) in this example.

```
rf_driver: {
    name: "sdr",

    /* list of devices. 'dev0' is always the master. */
    args: "dev0=/dev/sdr0,dev1=/dev/sdr1",

    /* TDD: force the RX antenna on the RX connector */
    rx_antenna: "rx",

    /* synchronisation source: none, internal, gps, external (default = none) */
    // sync: "gps",

    rx_chan_mapping: "1",
}
```

Now, let's consider another example with 2 cells MIMO 4x4 in DL and SISO in UL. This configuration can be run on two SDR100 cards as depicted below.



Two cells MIMO 4x4

The first cell (rf\_port 0) is in n78 and the second one is in n41. Let's consider again that a TELIT CPE is used where the UL main antenna is ANT1 in case of n78 and ANT2 in case of n41. There is still one single layer in UL. In this case, rx\_chan\_mapping should include 2 indexes, one for each RF port. The first index refers to the RX port used to receive the UL in rf\_port 0 (Cell 1 in n78) while the second one is the RX port index in rf\_port 1 (Cell 2 is n41).

The following rx\_chan\_mapping means that the UL stream is expected to be received on the RX2 of the first SDR100 board and on the RX3 of the second SDR100 board.

```
rx_chan_mapping: "1,2",
```

Now let's consider the same example as above with 2 cells but this time UL is in MIMO 2x2 in both cells. Remember that Telit CPE uses ANT1 and ANT2 as main and diversity antenna for n78 and ANT2 and ANT0 as main and diversity antenna for n41. With respect to the cabling of the above diagram, the rx\_chan\_mapping should be as follows.

```
rx_chan_mapping: "1:2,2:0",
```

In the rf\_port 0 (n78 cell), the RX2 and RX3 ports are used to receive the UL stream 0 and stream 1 while in the rf\_port 1 (n41 cell), the RX ports RX3 and RX1 are used.

## 2.8 FR2 support

The SDR100 card supports a frequency range of 300 MHz to 6.0 GHz. In order to provide a FR2 signal for mmwave testing, an external up down converter (UDC) should be used. Typically the UDC is connected by a RF cable to the TX and RX ports of the SDR card to up and down convert a sub-6 GHz signal to a mmwave signal.

Most UDCs should be configured first for the target output frequency. This configuration could be done automatically by setting config\_script and config\_script\_params inside the rf\_driver object. Amarisoft provides an example script udc-config.sh available under enb/config/sdr directory. This example script works with Amarisoft UDC and should be adapted if another type is used.

### 2.9 TDD support

The board integrates a TX/RX switch for TDD operation. When TDD operation is configured, the transmit and receive are done on a single RF port (the TX SMA connector). So you only need to connect antennas on the TX1 and TX2 SMA connectors for TDD operation.

## 2.10 GPS usage

You can check the GPS operation when the eNodeB/UE is stopped with

```
./sdr_util gps_state
```

The GPS takes a few minutes to lock if the GPS antenna is connected. Any active GPS antenna accepting a 3.3V DC supply can be used, for example: http://www.mouser.fr/Search/ProductDetail.aspx? R=ANT-GPS-SH-SMAvirtualkey590000000virtualkey712-ANT-GPS-SH-SMA

To ensure the PLL is correctly locked when launching the lte software, it is recommended to set the synchro to GPS beforehand with the command

```
./sdr_util sync_gps
```

## 2.11 Oscillator frequency automatic tuning from GPS

When the GPS is active, you can fine tune automatically the VCTCXO and store the adjustment value in flash to be used on all following sessions.

```
./sdr_util gps_cal -s
```

## 2.12 Oscillator frequency fine tuning

If you don't have a GPS, it is still possible to manually fine tune the VCTCXO (Voltage Controlled, Temperature Controlled Crystal Oscillator) frequency provided you have a way to know the offset:

```
./sdr_util clock_tune n
```

where n is the offset in PPM (parts-per-million) from the nominal TCXO frequency. Note: the PPM offset n to voltage law is only approximative, so you should adjust it by successive approximation.

## 3 TRX driver configuration options

## 3.1 Single card configuration

The following properties are available:

name String. Set the driver to use, always set "sdr" to use Amarisoft driver.

args String. Set the system device names for the boards. Example:

args: "dev0=/dev/sdr0"

args: "dev0=/dev/sdr0,dev1=/dev/sdr2"

#### sample\_hw\_fmt

Optional enumeration (auto, ci16, cf8) (default = auto). Set the sample format used on the PCI bus. auto selects the best format depending on the available PCI bandwidth. ci16 selects 16 bit complex integers. cf8 selects 8 bit complex floats giving a 2:1 compression ratio while retaining the full 12 bit amplitude of the ADCs and DACs.

#### rx\_antenna

Optional enumeration (auto, tx\_rx, rx) (default = auto). Select the connector on which the RX antenna is connected. By default it is connected on the RX connector for FDD and on the TX/RX connector for TDD. This parameter is useful to force the use of the RX connector in TDD.

#### fifo\_tx\_time

Optional number. Set the DMA TX buffer size in us.

Decreasing this value will improve latency but may lead to signal samples loss if the PCIe chain on the motherboard is not fast enough. This can be detected with the rf\_info monitor command of your lteenb or lteue software. If such situation happens, the percentage of TX buffer Usage will be 100% which means the transmission path has encountered underflows.

#### fifo\_rx\_time

Optional number. Set the DMA RX buffer size in us.

Same as fifo\_tx\_time for RX chain but reducing it won't improve latency.

#### pps\_extra\_delay

Optional float value in microseconds, range: [-10000.0 .. +10000.0] (-10ms to +10ms) Adds a delay between GPS pulse and start of DL frame. If the pps\_extra\_delay value is negative, the actual delay will be (10ms + pps\_extra\_delay). For instance, if you want to compensate for 250ns delay caused by cable length, you will set pps\_extra\_delay: -0.25, the software will add (10ms - 250ns) to the GPS pulse.

#### tdd\_tx\_mod

Optional number value: 0 (default) or 1. If set to 1, the TX amplifiers will be switched on and off according to the TDD state.

#### rx\_chan\_mapping

Optional string. By default, if radio frontend has more RX channel available than configured (Ex: more physical RX connctor on SDR or more channel in CPRI hyperframes), drivers uses the first channels of the radio frontend.

This parameter allows to select the RX channels of the radio frontend to use.

This parameter is a list of number (Must have as many number as RF port configuration) separated by colons. Each number represents the RX channel of the radio frontend to use.

Ex: If a RF port has 4 TX antenna and 2 RX antenna, by default driver will use RX1 and RX2 of first SDR board. By setting:

1:2

RF driver will use RX2 of first board as primary RF port channel and RX1 of second board as secondary RF port channel.

With:

3:1

RF driver will use RX2 of second board as primary RF port channel and RX2 of second board as secondary RF port channel.

Optional enumeration: none, internal, gps, external (default = none). Set the time synchronization source. none and internal uses the internal PPS generated from the clock. internal synchronizes the RX timestamps on the internal PPS. none does not synchronize the RX timestamps on the internal PPS for a faster startup. gps uses the internal GPS. external uses the PPS from an external source (see below).

When several cards are selected (with the args property), sync only sets the time synchronization source of the first card. The other cards are implicitly set to external synchronization, assuming the previous card is used as source.

clock Optional enumeration: internal, external (default = internal). Set the clock source.

internal uses the internal clock (VCTCXO). If an external time source is used, the
internal clock frequency is adjusted by the PPS signal.

Special cases:

- 1. If both clock and sync are external, the clock and PPS from the CLK\_IN connector is used.
- 2. If clock is external and sync is internal, then an external reference clock is taken from the EXT\_CLK UFL connector in the middle of the board (Figure 7.1). Two reference frequencies are supported on this connector: 38.40 MHz and 30.72 MHz (auto detect).
- 3. If clock is internal and sync is external, then the internal clock generator is synchronized to an external PPS signal connected on the FPGA0\_PPS UFL connector (CMOS 3v3) (Figure 7.1).

gpio0 Optional enumeration. Selects the signal ouput on connector GPIO0. See below for possible values. Default = rf\_dts1.

optional enumeration. Selects the signal ouput on connector GPIO1. See below for possible values. Default = rf\_dts2.

#### gpio values:

| Value                          | Description                                                                                                               |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------|
| zero                           | output a constant low level signal (OV)                                                                                   |
| one                            | output a constant high level signal (3.3V)                                                                                |
| $rf_{-}dts1$                   | in TDD mode, output a high level when the TX is active on channel 1. Polarity can be inverted by setting dts_polarity:    |
|                                | low                                                                                                                       |
| $\mathrm{rf}_{-}\mathrm{dts}2$ | in TDD mode, output a high level when the TX is active on channel 2 Polarity can be inverted by setting dts_polarity: low |

| $pps\_selected$                                       | output a positive going Pulse per Second from the currently   |  |
|-------------------------------------------------------|---------------------------------------------------------------|--|
|                                                       | selected sync                                                 |  |
| $pps_ext$                                             | output a positive going Pulse per Second from the EXT PPS     |  |
|                                                       | UFL onboard connector                                         |  |
| $pps\_prev$                                           | output a positive going Pulse per Second from the CLKIN inter |  |
|                                                       | board connector                                               |  |
| $pps_gps$                                             | output a positive going Pulse per Second from the onboard GPS |  |
|                                                       | module                                                        |  |
| pps_vcxo                                              | output a positive going Pulse per Second from the onboard     |  |
|                                                       | generator                                                     |  |
| $dma_tx$                                              | output a positive front on each TX DMA packet (synced on      |  |
|                                                       | current selected PPS)                                         |  |
| $\mathrm{dma}_{-}\mathrm{rx}$                         | output a positive front on each RX DMA packet                 |  |
| dma_tx_100Hzoutput a 100 Hz signal synced with dma_tx |                                                               |  |
| dma_rx_100Hzoutput a 100 Hz signal synced with dma_rx |                                                               |  |

#### dts\_polarity

Optional enumeration: high (default), low. Selects the polarity for both rf\_dts1 and rf\_dts2 signals and also on DTS UFL connectors.

The range for the transmit gain (tx\_gain parameter in eNodeB/UE) is from 16 to 90 dB. The range for the receive gain (rx\_gain parameter in eNodeB/UE) is from 9 to 60 dB.

The maximum sample rate is 122.88 MHz. Not all sample rate are available: only 122.88 61.44 and 30.72 MHz.

## 3.2 Multiple card configuration

All single card configuration parameters apply to multiple card mode.

To differentiate configuration for each card, the syntax of some parameter will change to a list of value separated by commas (,).\* The first value will apply to the first board defined in args argument, ...

This syntax applies to the following parameters:

- pps\_extra\_delay
- fifo\_rx\_time
- fifo\_rx\_ratio
- fifo\_tx\_time
- fifo\_tx\_ratio
- rx\_chan\_mapping

## 4 Troubleshooting

Below are a few tips on how to handle different errors.

• The eNodeB does not start and the output of dmesg linux command resembles the following error message:

```
sdr: version magic '4.12.9-200.fc25.x86_64 SMP mod_unload' should be '4.12.11-200.fc25.x86_64 SMP mod_unload'
```

To resolve it, you need to recompile the SDR driver on the PC (See [Manual Installation], page 2).

### 5 Miscellaneous utilities

#### 5.1 sdr\_util

usage: sdr\_util [options] cmd [args...] Options: -h help select the device (default = all) -c device\_num Available commands: version dump the FPGA version sync\_state dump the synchro and clock state gps\_state dump the GPS state select GPS as sync source, wait for stable state sync\_gps gps\_cal [-s] uses the GPS sync to tune VCXO, optionnaly stores the value in f dump the temperature of the board components temp led [0|1] enable/disable led blinking clock\_tune n tune TCXO frequency offset to n ppm upgrade [options] upgrade the FPGA firmware upgrade options are: -force force upgrade even if identical or

## 5.2 sdr\_spectrum

sdr\_spectrum is a real time spectrum analyzer, sample viewer and I/Q file recorder. It handles several channels at the same time. It can be invoked without arguments. The following options are available:

previous version

```
-h
           help
-args str set the device arguments (default="dev0=/dev/sdr0")
-rx_freq freq
           set the RX frequency in Hz (default=2400000000)
-rate rate
           set the sample rate to 'rate' Hz (default=122880000 for SDR100)
-rx_gain gain
           set the RX gain in dB (default=60)
-channels c
           set the number of RX channels to 'c' (default=1)
           set the analog receive bandwidth in Hz (default=same as sample rate)
-rx_bw
-sync source
           set the sync source to 'source' (none, internal, gps, external) (default=none)
-clock source
           set the clock source to 'source' (internal, external) (default=internal)
-save_path path
           set the directory where the recorded samples are saved (default=/tmp)
-duration d
           set the recorded sample file duration in seconds when saving (default=1.0)
```

-save starts recording samples automatically from program start.

#### -save-and-exit

same as -save but program will quit at end of recording.

When saving the recorded samples, one file is generated per channel. The filename contains the UTC date, the frequency and the channel number. The I/Q samples are saved as little endian 32 bit float values, in I/Q order. The sample values are between -1 and 1.

Invocation example:

./sdr\_spectrum -channels 2 -rx\_gain 50 -rx\_freq 2680e6 -rate 122.88e6 Resulting output:



sdr\_spectrum is interactive and allow actions during runtime:

#### keys

available keys are indicated in the left side text area.

#### left mouse button

select a range and the X-Y values are displayed on the bottom of the graph.

#### right mouse button

in spectrum mode, highlight a range and get a measure of the power inside the range.

### 5.3 sdr\_play

sdr\_play is an I/Q file player. Several channels can be played at the same time and they can be time synchronized on an external clock. One file must be provided per channel. The following options are available:

-h help

```
-args str set the device arguments (default="dev0=/dev/sdr0")
-tx_freq freq
           set the TX frequency in Hz (default=2400000000)
-rate rate
           set the sample rate to 'rate' Hz (default=122880000 for SDR100)
-tx_gain gain
           set the TX gain in dB (default=70)
-channels c
           set the number of channels to 'c' (default=1)
-tx_bw bw set the analog transmit bandwidth in Hz (default=same as sample rate)
-loop
           play the file in loop
-sync source
           set the sync source to 'source' (none, internal, gps, external) (default=none)
-clock source
           set the clock source to 'source' (internal, external) (default=internal)
-time_offset n
           offset the output by n samples (default=0)
  The sample files should contain the I/Q values as little endian 32 bit floats, in I/Q order.
The sample values should be between -1 and 1.
5.4 sdr_test
sdr_test is a general diagnostic tool for SDR boards.
usage: sdr_test [options] cmd [args...]
-h
           help
-c device_num
           select the SDR device number (default=0)
-d channel
           select the device channel (default = 0). useful for CPRI boards.
dma_loopback_test [n][sec]
           test DMA loopback on 1 or n devices for sec seconds (def: 10)
rfic_tx_test sample_rate freq tx_gain waveform [tone_freq/ofdm_bw]
           test RFIC TX (freq in Hz, tx_gain in dB from 0 to 90)
           waveform can be:
            zero for no signal
            prbs for PRBS simulation,
            tone for CW at specified offset from center freq (default = 7.68e6)
            ofdm for OFDM simulation on specified bw (default = auto)
flash_check
           verify checksum of code in onboard FPGA.
flash_reload
           reload FPGA code from onboard flash
gps_read
           GPS read test (best with GPS antenna)
```

```
led
          blinks onboard led during 5 seconds for identification
synchro_set [src]
          Set the source for PPS synchronisation
           0=internal
           1=GPS
           2=slave
           3=ext PPS
           4=CPRI
           5=ext CLK
synchro_state
          Show current status of clock and synchro source for SDR device
          Example:
           sync_source = 0 (internal)
           pps_locked = 1
           clock_source = 0 (internal)
           clock_pll_locked = 1
version
          Show SDR device Hardware and firmware information
          Example:
           Board ID:
                              0x4b21
           Board master:
                              0x1
           Board revision:
                              0x1
           FPGA revision:
                              2023-06-23 09:51:49
           FPGA status:
                              operational
           Software version: 2023-11-14
dump_info
          dump fpga and RF chip information (similar to sdr_util version)
          Example:
          PCIe SDR TRX driver 2022-02-25
          PCIe RFIC /dev/sdr0@0:
            Hardware ID: 0x4b21
            DNA: [0x29445505617111124]
            Serial: '123456789012'
            FPGA revision: 2023-06-23 09:51:49
            FPGA vccint: 1.02 V
            FPGA vccaux: 1.79 V
            FPGA vccbram: 1.02 V
            FPGA temperature: 50.1 C
            AD9371 temperature: 30 C
            AGC: Off
            Sync: internal (locked)
            Clock: internal (locked)
            Clock tune: 0.3 ppm
            NUMA: O
            DMA: 1 ch, 64 bits, SMem index: On
            DMAO TX_Underflows: 65535 RX_Overflows: 0
            PCIe bus: bus=0x67 FPGA PCI gen2 x4 (16.0Gb/s) Bridge PCI gen2 x8 (32.0Gb/s)
```

gpio 0|1 [value]

Get or set the signal available on GPIO points on the board See gpio0 and gpio1 in chapter TRX driver configuration options;

## 6 C API

The PCIe SDR board can be used in other projects with its C API. The C API allows to send and receive I/Q samples and to change the various parameters (frequency, sample rate, bandwidth, gains, ...). The Amarisoft TRX driver, sdr\_play and sdr\_spectrum are built using this API.

The C API is described in libsdr.h. The corresponding Linux x86\_64 dynamic library is libsdr.so.

Amarisoft does not provide any support for this API and can modify it without notice.

## 7 Physical specifications

## 7.1 Summary

- RF power output < 15 dBm
- Max RF input power: ~ +3 dBm RMS (+15dBm peak) with rx\_gain < 39; 20 dB less with rx\_gain > 39
- 8 SMA female (TX1, TX2, TX3, TX4, RX1, RX2, RX3, RX4), AC coupled
- 1 SMA female (GPS antenna with 3.3V DC power supply)
- 1 input + 3 output SATA connectors for inter-card time synchronization
- PCIe gen2 x8, full height, full length
- Uses single 12V power supply from PCI connector
- ADC/DAC Sample Rate: 122.88 MS/s
- ADC/DAC Resolution: 12 bits
- Frequency Accuracy: < 1 ppm
- LTE 20MHz 64QAM EVM < 2 %rms (f < 2.6 GHz)
- LTE 20MHz 64QAM EVM < 4 %rms (f < 3.5 GHz)
- Full size (L x W x H): 128mm x 220mm x 20mm
- Weight: ~0.300 kg
- Power (PCIe 12V): 1A idle => 12W, 2.8A maximum (4x4 max tx\_gain) => 33.6W

#### 7.2 Connectors

The following figure depicts the location and functionality of each connector in the PCIe board.



Figure 7.1



Figure 7.2



Figure 7.3

## 7.2.1 SMA connectors

On Figure 7.1, the connector names are:

TX3 (and RX3 for TDD): first RF port of secondary device on this board (sdr1)

RX3 (for FDD)

RX4 (for FDD)

TX4 TX4 (and RX4 for TDD): second RF port of secondary device on this board

TX1 TX1 (and RX1 for TDD): first RF port of primary device on this board (sdr0)

RX1 RX1 (for FDD)

RX2 RX2 (for FDD)

TX2 TX2 (and RX2 for TDD): second RF port of primary device on this board

GPS connector for active GPS antenna

#### 7.2.2 SATA PPS/Clock connectors

Clock sync connectors

CLK\_IN Input to sync this board as slave.

CLK\_OUTO Output to use this board as master for other SDR100 board

CLK\_OUT1 Output to use this board as master for other SDR100 board

CLK\_OUT2 Output to use this board as master for other SDR100 board

On each SATA connector:

pin 2,3 LVDS signal: 122.88MHz clock

pin 6,5 LVDS signal: 38.40MHz bursts. each burst starts indicates the PPS

pins 1,4,7

Ground

#### 7.2.3 UFL connectors

| EXT_CLK    | Analog Input for external clock: see section 2.7: high level from 350mV to 3.3V        |
|------------|----------------------------------------------------------------------------------------|
| EXT_PPS    | CMOS Input for external sync: see section 2.7                                          |
| FPGAO_DTS1 | CMOS output for TX1/RX1 TDD mode: 3.3V in TX mode, 0V in RX mode                       |
| FPGAO_DTS2 | CMOS output for TX2/RX2 TDD mode: 3.3V in TX mode, 0V in RX mode                       |
| FPGA1_DTS1 | CMOS output for TX3/RX3 TDD mode: 3.3V in TX mode, 0V in RX mode                       |
| FPGA1_DTS2 | CMOS output for TX4/RX4 TDD mode: $3.3\mathrm{V}$ in TX mode, $0\mathrm{V}$ in RX mode |

The DTS signals can be used to control external TX amplifiers.

They are available also when 'rx\_antenna: rx' is selected.

The polarity can be changed with parameter 'dts\_polarity' indicating the level of the TX mode: dts\_polarity can be set to 'high' (default) or 'low'.

#### 7.2.4 GPIO connectors

On Figure 7.3, the connector names are:

```
connector for TX1/TX2 GPIO signals
CN22
           pin 1
                      gpio0 (square solder pad)
                      gpio1 (center pin)
           pin 2
           pin 3
                      Ground
CN23
           connector for TX3/TX4 GPIO signals
                      gpio0 (square solder pad)
           pin 1
           pin 2
                      gpio1 (center pin)
           pin 3
                      Ground
```

see gpio0 and gpio1 in chapter TRX driver configuration options;

## 7.3 RX power

Maximum RX power on any RX port to avoid damage:

rx gain >= 39 : -15dBm RMS $rx_gain < 39 : +5dBm RMS$ 

## 7.4 TX power

Maximum TX Power versus RF frequency, measured on OFDM BW = 100MHz.

| m dBm/MHz | dBm                                                                                           |
|-----------|-----------------------------------------------------------------------------------------------|
| -8.0      | 12.0                                                                                          |
| -8.0      | 12.0                                                                                          |
| -11.0     | 9.0                                                                                           |
| -12.0     | 8.0                                                                                           |
| -16.0     | 4.0                                                                                           |
| -15.0     | 5.0                                                                                           |
| -17.0     | 3.0                                                                                           |
| -23.0     | -3.0                                                                                          |
| -29.0     | -9.0                                                                                          |
| -30.0     | -10.0                                                                                         |
| -32.0     | -12.0                                                                                         |
| -40.0     | -20.0                                                                                         |
|           | -8.0<br>-8.0<br>-11.0<br>-12.0<br>-16.0<br>-15.0<br>-17.0<br>-23.0<br>-29.0<br>-30.0<br>-32.0 |

## 8 Remote API

```
SDR driver implements the trx remote API.

Message definition:

command Optional string. Can be:

• clock_tune

Exemple:
```

```
Exemple:
{
    "message": "trx",
    "command": "clock_tune"
}
```

Here are the additional request and response field depending on  ${\tt command}$  value:

### 8.1 clock\_tune

Request fields:

offset Optional number. If command is clock\_tune, defines the clock drift to set in ppm.

## 9 Change history

## 9.1 Version 2025-06-13

• Added rx\_chan\_mapping configuration parameter

### 9.2 Version 2024-06-14

• Added remote API support

## 9.3 Version 2023-09-08

• Added NUMA support

### 9.4 Version 2023-06-10

- Added tdd\_tx\_mod configuration parameter
- New FPGA firmmware version 2023-05-24

## 10 License

trx\_sdr100 is copyright (C) 2012-2025 Amarisoft. Its redistribution without authorization is prohibited.

 ${\tt trx\_sdr100}$  is available without any express or implied warranty. In no event will Amarisoft be held liable for any damages arising from the use of this software.

For more information on licensing, please refer to license.pdf file.