by Fairwaves

The first ever truly embedded SDR

$386,055 raised

of $90,000 goal

428% Funded! Order Below

Product Choices



Get an XTRX Pro board. Does not include any cables, antennas, or adapter boards.


PCIe x2 Lite Adapter

This PCIe card securely holds an XTRX board (not included) so it can be used in a standard PCIe x4 slot. This adapter achieves the full 10 Gbit/s raw bus bandwidth and can be plugged into x4/x8/x16 PCIe slots. A six-pin JTAG connector makes it easy to program and debug the FPGA. Includes six SMA-to-U.FL cables, two screws for mounting your an XTRX board, and four 8 cm U.FL-to-U.FL cables.


Antennas + Cables

A full complement of cables and antennas for your XTRX, including four RF antennas (95 mm, 2 dBi, SMA male, GSM/3G/LTE 880 - 960 MHz, 1710 - 1990 MHz), one GPS antenna, and five cables.


Recent Updates

As Featured In


"XTRX – A high-performance SDR in a mini PCIe form factor"


"It ... has a tuning range of 10 MHz - 3.7 GHz, with a sample rate of up to 120 MSPS. It is also has some interesting additional features such as a built in GPSDO and an onboard FPGA which can be used to accelerate DSP tasks as well."


"Con un formato compacto y alto rendimiento, este módulo SDR embebible XTRX es útil para sistemas embebidos y drones a nivel profesional."


"The Fairwaves “XTRX” mini-PCIe SDR card is a low-cost embeddable SDR card aimed at high data rate apps including 4G/5G and “massive” MIMO."

Hackster News

"The Fairwaves XTRX, now raising on Crowd Supply, is... something rather different."


"The XTRX’s main features are the integrated GPSDO (GPS Disciplined Oscillator), the compact size (just 30x51mm) and the 120MHz max RF bandwidth (!)."


"Fairwave’s XTRX, a 'truly' embedded SDR (software-defined radio) module now up as a Crowd Supply crowdfunding project, manages to pack an entire 2x2 MIMO SDR with an RF tuning range of 30MHz to 3.8GHz into a diminutive Mini PCIe format."

Open Electronics

"A low-cost embeddable SDR card aimed at high data rate apps including 4G/5G and 'massive' MIMO."

CNXSoft - Embedded Systems News

"Fairwaves is a startup that aims to make deploying and operating mobile networks in rural regions profitable, and their latest project is called XTRX, a high performance Software Defined Radio (SDR) board packed into a mini PCIe card form factor."

XTRX is the smallest easily embeddable software-defined radio (SDR). It is both affordable and high-performance. XTRX is designed to enable the next generation of wireless solutions, from prototype to production.

LTE modems and GPS receivers are commodity parts easily bought in any electronic components store and added to your project. On the other hand, everyone designing an SDR-based product had to spend precious time and money on a custom design — until XTRX.

Don’t waste your time designing yet another SDR. Embedding XTRX into your product is easy, freeing you up to focus on what your customers really need.


XTRX is the best platform available today for building SDR-based products. We designed it with demanding embedded applications in mind:

  • Best-in-class Performance: 2 x 2 MIMO, 120 MSPS SISO / 90 MSPS MIMO, and more
  • Compact Form Factor: as a Mini PCIe card, it's the smallest commercially available SDR
  • Thermal Coupling: well-designed thermal interface to a heatsink
  • Stable Clock: accurate enough for cellular standards
  • GPSDO: on-board GPS disciplined oscillator
  • Synchronized Clocks: share the same clock source across many boards
  • SIM Card Reader: appears as a typical USB serial SIM card reader
  • High-speed GPIO: 12 total, of which eight can form four matched LVDS lines

If You’ve Ever Cursed Your SDR…

XTRX isn’t for everyone. We expect most people interested in XTRX to already have some experience with SDRs. If you’ve never used an SDR before, XTRX might be a bit overwhelming for you. XTRX might be right for you if you have:

  • deployed SDR-based solutions in the field
  • wanted to develop a massive MIMO system only to realize you don't have $1 million
  • cursed your SDR (or USB) for its latency, reliability, or cables
  • yearned to level-up your SDR skills with cutting-edge equipment

If this describes you, or you are looking for a better SDR, fear not and read on!

XTRX revision 3 (top)

Use Cases

Here are just a few of the things you could use XTRX for:

Massive MIMO System

XTRX boards can share the same sampling and reference clocks, which makes it easy to build a massive multiple input, multiple output (MIMO) system.

Monitor Massive Amounts of Bandwidth

With synchronized clocks, multiple XTRX boards can collectively monitor very large chunks of the RF spectrum. For example, eight synchronized XTRX boards could monitor nearly 1 GHz of bandwidth.

LTE Cellular

The combination of XTRX’s accurate, stable clock, on-board GPSDO, and low-latency PCIe bus makes LTE possible out of the box.

Software-defined 2G/3G/4G Modem

When inserted into a Mini PCIe slot reserved for cellular modems, XTRX appears as a USB SIM card reader.

Drones and Embedded Systems

Power consumption, weight, size, and performance all matter when it comes to drones and embedded systems. XTRX’s Mini PCIe form factor and GPIO enable you to interface with a wide variety of single board computers, sensors, and actuators.

DSP Acceleration

You can use the FPGA to accelerate your real-time signal processing; the high-speed, low-latency PCIe bus allows shuttling data back and forth between the host CPU and XTRX’s FPGA.

XTRX revision 3 (bottom)

Features & Specifications

  • RF Chipset: Lime Microsystems LMS7002M FPRF
  • FPGA Chipset: Xilinx Artix 7 35T/50T (CS/Pro)
  • Channels: 2 × 2 MIMO
  • RF Output Power: 0 to 10dBm depending on frequency
  • Sample Rate: ~0.2 MSPS to 120 MSPS SISO / 90 MSPS MIMO
  • Tuning Range: 30 MHz - 3.8 GHz
  • Rx/Tx Range:
    • 10 MHz - 3.7 GHz
    • 100 kHz - 3.8 GHz with signal level degradation
  • PCIe Bandwidth:
    • PCIe x2 Gen 2.0: 8 Gbit/s
    • PCIe x1 Gen 2.0: 4 Gbit/s
    • PCIe x1 Gen 1.0: 2 Gbit/s
  • Reference Clock:
    • Frequency: 26 MHz
    • Stability w/o GPS: 100 ppb or 500 ppb over the temperature range (depends on the XTRX version)
    • Stability w/GPS: <10 ppb stability after GPS/GNSS lock
  • Form Factor: full-size Mini PCIe (30 × 51 mm)
  • Bus Latency: <10 µs, stable over time
  • Synchronization: synchronize multiple XTRX boards for massive MIMO
  • GPIO:
    • FPC Edge Connector: four lines (usable as two diff-pairs)
    • Mini PCIe Reserved Pins: eight lines (including two diff-pairs, 1pps input, 1pps output, TDD switch control, and three LEDs)
  • Accessories:
    • Antennas + Cables
    • USB 3 Adapter with Aluminium Enclosure
    • PCIe x2 Lite Adapter

Block Diagram

Documentation & Sources

We’re publishig all XTRX-related code under the xtrx-sdr GitHub organization. The most important repositories to note:


Tuning range30 MHz - 3.7 GHz 30 MHz - 3.7 GHz 70 MHz - 6 GHz300 MHz - 3.8 GHz30 MHz - 3.8 GHz10 MHz - 3.5 GHz22 MHz - 2.2 GHz
DuplexFull MIMO Full MIMO Full MIMO Full SISOFull MIMO Full SISORX only
Max sampling rate120 MSPS SISO / 90 MSPS MIMO 120 MSPS SISO / 90 MSPS MIMO 61.44 MSPS40 MSPS61.44 MSPS30.72 MSPS3.2 MSPS
ADC/DAC resolution12-bit 12-bit 12-bit12-bit12-bit12-bit8-bit
Max RF bandwidth120 MHz 120 MHz 56 MHz28 MHz61.44 MHz30.72 MHz3.2 Mhz
Channels2 2 1 (2 for B210)12 11
Transmit power0 to 10dBm (depending on frequency) 0 to 10dBm (depending on frequency) 10dBm+6dBm0 to 10dBm (depending on frequency)0 to 10dBm (depending on frequency)none
RF chipsetLMS7002M LMS7002M AD9364 or AD9361LMS6002MLMS7002MLMS7002MRTL2832U
FPGAXilinx Artix7 35T Xilinx Artix7 50T Xilinx Spartan 6 XC6SLX75Altera 40KLE/115KLE Cyclone 4Altera 40KLE Cyclone 4Altera MAX 10none
Embeddedyes yes nonononono
Industrial temperature rangenoyes noOptional nonono
Temperature sensorsyes yes nonoyes nono
Frequency stability±0.5 ppm w/o GPS lock, <±0.01 ppm w/ GPS lock ±0.1 ppm w/o GPS lock, <±0.01 ppm w/ GPS lock ±2 ppm±1 ppm±2.5 ppm±2.5 ppm±25 ppm
GPS synchronizationon board on board Addon (+$636)nononono
Bus/interfacePCIe x2, USB 3 adapter, and more (FPGA based) PCIe x2, USB 3 adapter, and more (FPGA based) USB 3USB 3USB 3USB 3USB 2
Raw bus bandwidth10 Gbit/s 10 Gbit/s 5 Gbit/s5 Gbit/s5 Gbit/s5 Gbit/s480 Mbit/s
Dimensions30 × 51 mm 30 × 51 mm 97 x 155 mm87 x 131 mm100 x 60 mm69 x 31.4 mm40 x 60 mm
Extra featuresGPIO, GPS, SIM card interface GPIO, GPS, SIM card interface GPIOGPIOGPIOGPIOnone
Multiple boards synchronizationSample clock and timestamps Sample clock and timestamps Sample clock and timestamps Sample clock and timestamps Sample clockSample clockno
Price$260 $490 $686 - $1,119 + $636 (for GPSDO)$415$299 $139 $10+
Price per channel$130 $245 $560 - $715 + $636 (for GPSDO)$415$150 $139 $10+

Conceptual plot of XTRX's market position

RF Bandwidth

Answering the simply stated question, "how much bandwidth can I capture with XTRX," is surprisingly difficult. Without going into too much detail, the two most important parameters which affect the answer are the RF frontend filter width and the ADC/DAC sampling rate.

In a quadrature sampling architecture, the ADC/DAC sampling rate equals the maximum theoretical RF bandwidth. So, if your XTRX is sampling at 90 million samples per second (MSPS) then your maximum theoretical RF bandwidth is 90 MHz. If your XTRX is sampling at 10 MSPS, the maximum theoretical RF bandwidth it can handle is 10 MHz. On the receive side, all frequency components of the signal outside of this sampled RF bandwidth will "alias," thus distorting the sampled digital signal.

To avoid aliasing, XTRX has built-in analog low-pass filters (LPFs) ranging from 1.4 MHz to 130 MHz (see the LMS7002M datasheet for the details). To capture the largest amount of radio spectrum, you should select the largest LPF filter which is still less than about ~80% of your sampling rate, or disable the built-in filter and use an external bandpass analog filter. For example, for 90 MSPS you would use 70 MHz, which would be how much of the RF bandwidth you actually receive.

Another important thing to keep in mind is that both channels of an XTRX unit can only be tuned to a single frequency - though independently for receive and transmit. For example, if you tune an XTRX to transmit at 1800 MHz and receive at 1900 MHz, both Tx channels will transmit at 1800 MHz, and both Rx channels will receive at 1900 MHz. This is an inherent limitation of the LMS7002M RF chipset we’re using since it has only one PLL shared by both transmit channels and one PLL shared by both receive channels.

Sampling Rate & Throughput Limits

As explained above, the sampling rate directly affects how much RF bandwidth you can work with. So, what limits the maximum sampling rate you can achieve with your XTRX?

  • XTRX sampling rate, which is effectively limited by the LMS7002M digital bus speed. After careful tuning, The maximum speeds we could reliably achieve were 90 MSPS in MIMO mode and 120 MSPS in SISO mode.
  • Operating system throughput and application processing speed, which depends on the specific application so much that it's not possible to generalize.
  • PCIe bus throughput between XTRX and the host, which we discuss in more details below.

Putting aside implementation-specific limitations, there are three parts of the PCIe standard which affect maximum data throughput:

  • PCIe 1.0/2.0 PHY 5/4b encoding: 80% efficiency vs clock speed
  • PCIe TLP size:
    • 16b/64b: 80% efficiency
    • 16b/128b: 88% efficiency (the most common)
    • 16b/256b: 94% efficiency
  • PCIe protocol control traffic: 95% to 99.5% efficiency (99.5% for large block transfers)

Given that XTRX supports PCIe 1.0 and PCIe 2.0, and can work with x1 or x2 PCIe lanes, the maximum data throughput depends on the exact PCIe configuration, as shown in the table below.

XTRX Maximum Data Throughput as a Function of PCIe Configuration

PCIe configurationClock speedRaw data speed128b TLP throughputLarge data blocks throughput
PCIe 1.0 x12.5 GT/s2.0 Gbps1,760 Mbps1,750 Mbps
PCIe 2.0 x1 or PCIe 1.0 x25.0 GT/s4.0 Gbps3,520 Mbps3,500 Mbps
PCIe 2.0 x210.0 GT/s8.0 Gbps7,040 Mbps7,000 Mbps

XTRX has 12 bits of ADC/DAC resolution, so the samples can be transferred over PCIe in three different formats: as-is (12 bits), cut down to 8 bits, or expanded to 16 bits. Each of these methods has its own advantages and disadvantages, as shown in the table below.

Trade-offs of Sample Lengths Transferred Over PCIe

Bits per sampleMaintains precision?Easy to process on the CPU?Bandwidth efficient?
16 bitsyes yes no
12 bitsyes no yes
8 bitsno yes yes

Since we need to transfer two samples (I and Q) for each of either one (SISO) or two (MIMO) channels, we arrive at the following table of maximum sampling rates we can (theoretically) transfer over different PCIe bus configurations. Green cells indicate combinations of sample rate and PCIe bus configuration where the sampling rate is not limited by the PCIe bus but is rather limited by the XTRX itself.

Maximum XTRX Throughput by Configuration

ModeIQ x Ch x bitsTotal bits/samplePCIe 1.0 x1 (max 1,750 Mbps)PCIe 2.0 x1 or PCIe 1.0 x2 (max 3,500 Mbps)PCIe 2.0 x2 (max 7,000 Mbps)
8-bit SISO2 x 1 x 816 bits109 Msps219 Msps 438 Msps
12-bit SISO2 x 1 x 1224 bits73 Msps146 Msps 292 Msps
16-bit SISO2 x 1 x 1632 bits55 Msps109 Msps219 Msps
8-bit MIMO2 x 2 x 832 bits55 Msps109 Msps 219 Msps
12-bit MIMO2 x 2 x 1248 bits36 Msps73 Msps146 Msps
16-bit MIMO2 x 2 x 1664 bits27 Msps55 Msps109 Msps

Why Mini PCIe?

We chose the Mini PCIe form factor for XTRX because it’s the best option for a high-speed, low-latency bus that is both physically compact and widely used. In other words, using Mini PCIe results in a device that is both high-performance and easily embeddable.

While it’s true that many laptops are moving away from Mini PCIe slots and toward M.2 slots, Mini PCIe is still the most popular PCIe form factor among standards-based, professional single-board computers (SBCs) and embedded systems. We will likely release an M.2 version of XTRX after the Mini PCIe version has been delivered.

We also considered USB 3 and Thunderbolt 3, but the former is high-latency and the latter is not yet very popular. However, should you want to use USB 3 or Thunderbolt 3, there are adapter boards for both.

PCIe x2 Lite Adapter

This PCIe card securely holds an XTRX board so it can be used in a standard PCIe x4 slot. Unlike standard PCIe adapter that only have one PCIe lane, the PCIe x2 Lite Adapter has two lanes. This adapter achieves the full 10 Gbit/s raw bus bandwidth and can be plugged into x4/x8/x16 PCIe slots, though it won’t fit into an x1 slot unless the slot has an open end. A six-pin JTAG connector on the edge is compatible with a JTAG-HS2 cable, so you can easily program and debug the FPGA.

Flexible Development


The XTRX hardware itself is proprietary, though the hardware accessories we designed for it (e.g., the USB 3 and PCIe adapters) are open hardware.


XTRX’s main FPGA code is open source and without a viral license, so not only can you modify the code, but you can also develop your own proprietary FPGA blocks. The FPGA is approximately 30% utilized. We will share a detailed utilization report in a future update. You can upload your own firmware with our USB 3 adapter board or with a JTAG cable and our PCIe adapter board. If you are good at soldering, you can even solder JTAG directly to the XTRX board — that’s how we programmed our first samples.

Host Software & Drivers

The host-side software and drivers are open source.

We developed our low-level API to maximize performance (i.e., we’re using a zero-copy interface). We provide a SoapySDR interface to our low-level library, so you can quickly start developing if you’re already familiar with SoapySDR. For example, using SoapySDR plugins, you can easily get UHD support. Of course, there’s always the option to interface directly to the low-level API if you don’t want to use SoapySDR or need to eek out the most bandwidth and lowest latency.

The USB 3 adapter relies on a libusb wrapper, so it will work on almost every platform libusb works on. In contrast, PCIe communication requires a kernel-level driver for direct memory access (DMA) and interrupt handling. Our host library talks to a device provided by the kernel driver. Currently, we have an implementation for Linux only. A Windows driver is in early stages of development and will be released later. We don’t plan to develop PCIe drivers for other platforms right away. Our Linux kernel driver exposes TTY devices for GPS, UART, and SIM card UART, so you can use existing software, like gpsd and xgps. The adapter also provides a kernel pulse per second (LinuxPPS) interface for handling the lowest levels of jitter in NTP-like applications.

By Professionals, For Professionals

Developing a cutting-edge product requires more than just snapping together a few ready-to-use pieces. Over the last year and a half, we’ve been through three major revisions and many minor revisions of XTRX to find the optimal ratio of price, performance, and power consumption. In order to deliver the best product possible at an incredible price, we took deep dives into many thorny issues. For example, we wrote our own PCIe DMA implementation so as to maximize bus throughput while staying within the constraints of the smallest Artix 7 FPGA.

We did this work so you wouldn’t have to. With XTRX, you can incorporate an SDR into your own designs without first becoming an expert in the rarefied art of SDR design.

A Brief History of Fairwaves and XTRX

At Fairwaves, we’re familiar with the problem of not being able to buy an off-the-shelf SDR. Way back in 2008, we had an idea to build an SDR-based GSM base station that could be deployed in real networks. We got a USRP1 and tried to run OpenBTS, only to struggle for days before realizing cellular standards require 0.05 to 0.1 ppm clock accuracy but the USRP1 has only 20 ppm clock accuracy. We needed a better clock, so we created ClockTamer, an open source, highly accurate, programmable clock source.

Soon after, we found the USB connection used by USRP1 was neither reliable nor easily embedded in a compact system. So, we created UmTRX, an industrial-grade SDR that became the basis of our UmSITE product, a rugged, network-in-a-box GSM base station that has been deployed around the world and has withstood everything from Saharan summers to Siberian winters.

In 2016, we started looking into 4G (a.k.a. LTE) and 5G wireless systems and realized we needed something better. Today, we’re launching XTRX to eliminate size, performance, and cost barriers to making the next generation of wireless solutions.



We are a vertically integrated vendor of cellular equipment focused on the needs of emerging markets. We are developing, manufacturing, deploying, and operating turn-key cellular network solutions including radio equipment, towers, power and backhaul all the way to a core network and SS7 interconnect. Our team has been building software-defined radios and systems based on them since 2009 and is well known for its ClockTamer, UmTRX, and UmSITE products.

Alexander Chemeris


Sergey Kostanbaev

Software & Firmware Development

Andrey Sviyazov

Hardware Design

Albert Gardiner


Andrey Bakhmat


Andy Avtushenko


See Also

Subscribe to the Crowd Supply newsletter, highlighting the latest creators and projects: