

# UNIVERSIDADE FEDERAL DO PARÁ INSTITUTO DE TECNOLOGIA FACULDADE DE ENGENHARIA DA COMPUTAÇÃO E TELECOMUNICAÇÕES

An FPGA-Based Radio Frontend for LTE Transmission on Cloud RAN

Gabriel Peixoto de Carvalho



# UNIVERSIDADE FEDERAL DO PARÁ INSTITUTO DE TECNOLOGIA FACULDADE DE ENGENHARIA DA COMPUTAÇÃO E TELECOMUNICAÇÕES

## Gabriel Peixoto de Carvalho

### An FPGA-Based Radio Frontend for LTE Transmission on Cloud RAN

Trabalho de Conclusão de Curso apresentado para obtenção do grau de Engenheiro em Engenharia da Computação, do Instituto de Tecnologia, da Faculdade de Engenharia da Computação e Telecomunicações.

BELÉM - PARÁ

## An FPGA-Based Radio Frontend for LTE Transmission on Cloud RAN

| Este trabalho foi julgado adequado em/                                                    | / para a obtenção do Grau de Engenheiro        |  |  |  |
|-------------------------------------------------------------------------------------------|------------------------------------------------|--|--|--|
| da Computação, aprovado em sua forma final pela banca examinadora que atribuiu o conceito |                                                |  |  |  |
| ·                                                                                         |                                                |  |  |  |
|                                                                                           |                                                |  |  |  |
|                                                                                           |                                                |  |  |  |
|                                                                                           | Prof. Aldebaro Barreto da Rocha Klautau Junior |  |  |  |
|                                                                                           | ORIENTADOR                                     |  |  |  |
|                                                                                           |                                                |  |  |  |
|                                                                                           |                                                |  |  |  |
|                                                                                           | Prof. Wilson Pacheco Ferreira                  |  |  |  |
|                                                                                           | COORIENTADOR                                   |  |  |  |
|                                                                                           |                                                |  |  |  |
|                                                                                           |                                                |  |  |  |
|                                                                                           | Prof. Francisco Carlos Bentes Frey Muller      |  |  |  |
|                                                                                           | MEMBRO DA BANCA EXAMINADORA                    |  |  |  |
|                                                                                           |                                                |  |  |  |
|                                                                                           |                                                |  |  |  |
|                                                                                           | Eng. Igor Mesquita de Almeida                  |  |  |  |
|                                                                                           |                                                |  |  |  |
|                                                                                           | MEMBRO DA BANCA EXAMINADORA                    |  |  |  |
|                                                                                           |                                                |  |  |  |
|                                                                                           |                                                |  |  |  |
|                                                                                           | Prof. Francisco Carlos Bentes Frey Muller      |  |  |  |
| DIRETOR DA FACULDADE DE ENGENHA                                                           | RIA DA COMPUTAÇÃO E TELECOMUNICAÇÕES           |  |  |  |

# Agradecimentos

Gabriel Peixoto de Carvalho

Viva como se voce fosse morrer amanha. Aprenda como se voce fosse viver para sempre.

# **List of Acronyms**

- 1. MIMO Multiple Input Multiple Output
- 2. BBP Baseband Processor
- 3. RF Radio Frequency
- 4. LTE Long Term Evolution
- 5. C-RAN Cloud-RAN or Centralized-RAN
- 6. RAN Radio Access Network
- 7. LVDS Low Voltage Differential Signalling
- 8. FDD Frequency Division Duplex
- 9. TDD Time Division Duplex
- 10. AGC Automatic Gain Control
- 11. PLL Phase Locked Loop
- 12. BTS Base Station
- 13. DCXO Digital Controlled Crystal Oscillator
- 14. LO Local Oscillator
- 15. BB Baseband
- 16. ADC Analog-to-Digital Converter
- 17. DAC Digital-to-Analog Converter
- 18. RSSI Receive Signal Strength Indication

- 19. FIR Finite Impulse Response
- 20. IIR Infinite Impulse Response
- 21. SNR Signal to Noise Rate
- 22. FMC FPGA Mezzanine Card
- 23. LPC Low PIn Count
- 24. HPC High Pin Count
- 25. UE User Equipment
- 26. SMA Subminiature Version A
- 27. FPGA Field Programmable Gate Array
- 28. ASIC Application Specific Integrated Circuit
- 29. SDR Software Defined Radio
- 30. RAN Radio Access Network
- 31. RAN Radio Access Network

# **List of Simbols**

b Taxa agregada de bits alcancavel para o sistema

# **List of Figures**

| 6.1  | AD9361 Functional Block Diagram    | 10 |
|------|------------------------------------|----|
| 6.2  | Receiver Signal Path               | 12 |
| 6.3  | Transmitter Signal Path            | 12 |
| 6.4  | AD9361 Block Diagram               | 13 |
| 6.5  | DCXO Behavior Graph                | 15 |
| 6.6  | AD9361 PLL Reference Block Diagram | 16 |
| 6.7  | AD9361 Digital Data Interface      | 18 |
| 6.8  | FDD Enable State Machine           | 20 |
| 6.9  | TDD Enable State Machine           | 21 |
| 6.10 | FMComms2 and its components        | 22 |
| 6 11 | FMComms2 and FPGA Block Diagram    | 23 |

# **List of Tables**

# **Contents**

| De  | Dedicatoria                     |     |  |  |  |
|-----|---------------------------------|-----|--|--|--|
| Ag  | Agradecimentos                  |     |  |  |  |
| Lis | List of Figures                 |     |  |  |  |
| Lis | List of Tables                  |     |  |  |  |
| Co  | ontents                         | xii |  |  |  |
| Re  | Resumo                          |     |  |  |  |
| Ab  | Abstract                        |     |  |  |  |
| Ι   | Introduction                    | 1   |  |  |  |
| 1   | Introduction                    | 2   |  |  |  |
| II  | Literature Review               | 3   |  |  |  |
| 2   | Software Defined Radio          | 4   |  |  |  |
| 3   | Cloud RAN Overview              | 5   |  |  |  |
| 4   | Digital Communications Overview | 6   |  |  |  |
| 5   | Long Term Evolution             | 7   |  |  |  |

|             |            |         |                                 | xiii |
|-------------|------------|---------|---------------------------------|------|
| II          | I Iı       | mplem   | entation                        | 8    |
| 6           | FM         | Comms2  | 2                               | 9    |
|             | 6.1        | AD936   | 61                              | . 9  |
|             |            | 6.1.1   | General Description             | . 9  |
|             |            | 6.1.2   | Receiver                        | . 10 |
|             |            | 6.1.3   | Transmitter                     | . 12 |
|             |            | 6.1.4   | Filtering                       | . 13 |
|             |            | 6.1.5   | Clocking                        | . 14 |
|             |            | 6.1.6   | Synthesizers                    | . 16 |
|             |            | 6.1.7   | Digital Data Interface          | . 16 |
|             |            | 6.1.8   | Enable State Machine            | . 17 |
|             |            | 6.1.9   | SPI Interface                   | . 19 |
|             |            | 6.1.10  | Auxiliary Converters            | . 19 |
|             |            | 6.1.11  | Applications                    | . 22 |
|             | 6.2        | FMCo    | mmS2                            | . 22 |
|             |            | 6.2.1   | Functional Overview             | . 23 |
|             | 6.3        | Basic N | Mathematical Background         | . 24 |
|             |            | 6.3.1   | Complex Modulation              | . 24 |
|             |            | 6.3.2   | Basic Modulation Mathematics    | . 25 |
| 7           | FPG        | SA      |                                 | 27   |
|             | 7.1        | ML605   | 5 - Virtex6                     | . 27 |
|             | 7.2        | VC707   | 7 - Virtex7                     | . 27 |
| 8 Setup Des |            | p Descr | ription                         | 28   |
|             | 8.1        | Overvi  | ew                              | . 28 |
|             | 8.2        | Integra | ation between FPGA and FMComms2 | . 28 |
| I           | / <b>F</b> | inal Ro | esults                          | 29   |
| 9           | Resu       | ılts    |                                 | 30   |
|             | 9.1        | Prelim  | inary Tests                     | . 30 |
|             | 9.2        | Transm  | nission Tests                   | . 30 |

|                              | xiv |
|------------------------------|-----|
| V Conclusion and Future Work | 31  |
| 10 Conclusion                | 32  |
| References                   |     |
| A PLL                        | 35  |
| B FPGA Design Flow           | 36  |
| C PLL                        | 37  |

# Resumo

## **Abstract**

The evolution of mobile services in terms of access technologies and application layers is driving a huge change in mobile communication systems. A recent hot topic in the field is the rise of the cloud computing paradigm, thus the idea known as cloud radio access networks (Cloud-RAN) is growing in the industry. This behavior comes from the potential of cloud-ification for improvement in the efficiency of resource allocation, manageability and power consumption, aspects inherent of traditional RANs.

Thus, with the emerging of C-RAN, several questions about how to implement and which tools to use come naturally. This work aims to evaluate the potential of a programmable fronthaul radio interface, as known, actual network does not have the adaptative capability needed for the C-RAN. For this work a setup of a radio unit, composed by two fpgas (one acting as the Baseband unit and other as the (digital front-end) of the radio unity) connected through ethernet and two transceivers (analog front-end), one in each FPGA. Within this setup various algorithms can be tested and can be evaluated in LTE scenarios because the transceiver works in LTE and C-RAN.

This work shall focus on the evaluation of the radio interface and perform the tests inherent to it, exploring FPGA adaptability and parallelism with the internal and external communication protocols, and so exploring the advantages of the transceiver used, the fmcomms2 development board (AD9361 chip) from Analog devices, which is a device broadly used in software defined radio hardwares, as known as USRPs (Universal Software Radio Peripheral).

An aspect of the transceiver that is very attractive to the C-RAN paradigm is its configurability and scalability, capable of real-time adjustments in the sampling frequency or operation mode from 2x2 to 4x4 MIMO (Multiple Inputs and Multiple Outputs), this real-time adaptive

characteristic is ideal to C-RAN environment.

The results are generated primarily aiming a fidelity in the transmitted and receiver signals, after these results are conclusive it is possible to proceed to more complex tests and approaches of this setup. Another test made was the analysis of the synchronization between receiver and transceiver using a CIPRI emulator implemented in FPGA logic, which is the standard fronthaul interface, in this test it is possible to observe the advantages of the programmable radio front-end in the system.

# Part I Introduction

# Introduction

# Part II Literature Review

# **Software Defined Radio**

# **Cloud RAN Overview**

# **Digital Communications Overview**

# **Long Term Evolution**

# Part III Implementation

## FMComms2

## 6.1 AD9361

The AD9361 is a high performance RF transceiver. Its programmability and adaptability makes it ideal for a wide range of transceiver applications. This device combines a RF front end with a flexible and configurable mixed-signal baseband section and frequency synthesizers, simplified configuration digital interface to a processor. The AD9361 operates from 70 MHz to 6.0GHz range with supported channel bandwidths from 200 KHz to 56 MHz and the AD9361 is a 2 Rx and 2 Tx device packed in a 10mm x10mm, 144 ball chip package ball grid array (CSP\_BGA).

## **6.1.1 General Description**

AD9361 is a highly integrated RF frequency transceiver capable of being configured for a wide range of applications, including 3g and 4g frequency applications. AD9361 and AD9364 almost the same hardware and specifications, the difference is that AD9361 is a 2x2 MIMO and AD9364 is a 1x1 [?]. The programmability allows the AD9361 to be operated in Frequency Division Duplex (FDD) and Time Division Duplex (TDD) systems, allowing this transceiver to operate in a variety of communication standards. Another interesting feature is the capability of integration with a wide range of BBPs (Baseband Processors) using a single or dual 12-bit parallel data port or a 12-bit LVDS (Low voltage Differential signaling), which uses the FMC connector in the FMCommS2 ??. AD9361 also provides self-calibration and automatic gain control (AGC) systems to maintain good performance under variable conditions, such as temperature and signal quality. The transceiver has also various modes of test mode with the

Built-in Self Test (BIST) modes which can be used for the designers to debug desgs during prototyping. This configurability and adaptability is very attractive for Software Defined Radio (SDR) and for C-RAN systems, indeed ad9361 is already being used in some Universal Software Radio Peripheral (USRP) from ettus research (National Instruments), this alone is a proof that AD9361 can work in a wide range of systems and standards.



Figure 6.1: AD9361 Functional Block Diagram

## 6.1.2 Receiver

The receiver section has all the blocks necessary to receive analog RF signals and convert them to digital data which can be used by the BBP. there are two independently controlled channels that share same frequency synthesizer. This characteristic makes possible to the AD9361 to operate in MIMO systems.

Each channel has 3 inputs which can be multiplexed into the signal chain, making possible to use the AD9361 into systems with multiple antenna inputs. The Receiver is a direct

conversion system that contains a Low noise amplifier (LNA), followed by a matched in-phase and quadrature amplifier, mixers, and band shaping filters that down convert received signals to baseband for digitization. External LNAs can also be interfaced to the AD9361 allowing more flexibility in the design. The receiver signal path passes downconverted signals (I and Q), which are schematically identical to each other, to the baseband (BB) receiver section. The BB section is composed by two programmable low-pass filters, with programmable corner frequency for each filter, 12-bit ADC and four stages of decimating filters, each of the four decimation filters can be bypassed. The gain control is achieved by a preprogrammed gain index map, a lookup table for example, this map distributes gain in order to achieve optimal performance at each level. This optimal behavior can be achieved by enabling AGC, which can run in two modes, fast and slow gain control. This allow for the BBP to make gain adjustments as needed. Each channel also contains independent RSSI measurement capability, DC offset tracking and all other circuitry needed for self-calibration.

The receiver ADC is a 12-bit sigma-delta ( $\Sigma - \Delta$ ) ADC which allows adjustable sample rates. This ADC produces data streams from the received signals and such digitalized signals can be conditioned further by a series of decimation filters and a 128-tap FIR filter with additional decimation settings. The sampling rate of each digital filter is adjustable through changes in the decimation factors to produce the needed data rate.

In short, the Receiver chain has:

- LNA Low noise Amplifier
- Matched in-phase amplifier;
- Quadrature Amplifier;
- Band Shaping Filters;
- Analog low pass filters;
- 12-bit DAC;
- 4 stages of decimation filters (128-tap FIR filters);
- Automatic gain Control;



Figure 6.2: Receiver Signal Path

### 6.1.3 Transmitter

Like the receiver section, the transmitter section contains two identical and independently controller channels, which share the same frequency synthesizer, that provide all digital signal processing, mixed signal and RF blocks necessary to implement a direct conversion system from digital data to RF. The Tx signal path receives from the BBP 12-bit 2s complement I-Q format data in the digital interface and each channel goes through a 128-tap FIR filter with interpolation options, which is fully programmable. Then the signal goes through a series of additional interpolation filters that manipulates the signal with additional filtering and data rate interpolation before reaching the 12-bit DAC, note that all these filtering and interpolation steps can be bypassed if desired. Each 12-bit DAC has an adjustable sampling rate and its analog output passes through to low pass filters to remove any sampling artifacts before going to the RF mixer, these low pass filters corner frequencies can be programmable too. After all these filtering and analog conversion steps, the I and Q signals are recombined and modulated in the carrier frequency, which can be adjusted by changing the synthesizer frequency. These analog combined signals passes through additional analog filters for better band shaping and then it can be transmitted to the output amplifier. Each Transmitting channel provides wide attenuation adjustment range with fine granularity in order to optimize SNR.



Figure 6.3: Transmitter Signal Path

Identical to the receiver chain, the transmitter chain has also built-in self-calibration circuitry into each transmitting channel providing an automatic real-time adjustment. The transmitter also provides a TX monitor block for each channel, this block monitors the transmission output and routes it back through an unused receiver channel to the BBP for signal monitoring, but these monitoring option is only available in TDD mode operation while the receiver is idle.

In short the transmission chain has:

- 128-tap FIR filters;
- Interpolation Filters;
- 12-bit DAC;
- Analog Low-pass Filters;
- Additional band shaping analog filters;
- Attenuation adjustment;
- self-calibration circuits;
- Tx signal Monitor.



Figure 6.4: AD9361 Block Diagram

# 6.1.4 Filtering

In both receiver and transmitter there are:

## Receiver

• Low pass filter: band shape to reduce adjacent-channel interference.

• Decimation Filter: up convert from the digital baseband rate (64.11MSPS max) to the actual ADC (640MSPS) rate.

#### **Transmitter**

- Low pass filter: remove sampling artifacts
- Interpolation Filter: down convert from the digital baseband rate (64.11MSPS max) to the actual DAC (320MSPS) rate.

In both digital and analog implementations these filters have impact the magnitude and the phase in passband, such behavior must be compensated in the system, and this compensation is usually done inside the 128-tap FIR filter. The FIR filter is not only used for low pass filter realization but also to compensate for magnitude and phase impacts created by the analog and digital half band filters in the desired baseband area.

These filters depend in various other systems to work properly, such systems are sample rates, clock, data rates which sets the half band filters, and the desired RF bandwidth, which sets the analog filters. the process of loading a filter and after changing anything in the system will negatively affect the overall baseband performance.

There is a filter too created by analog devices, which designs a low-pass filter and sets the FIR coefficients in order to ensure compensation for magnitude and phase changes in the analog or half band filters.

## 6.1.5 Clocking

The AD9361 has a series of internal PLL to generate and manipulate clock signals. There are fractional-n PLLs that generate the transmitter and receiver LO frequencies and there are the baseband PLL (BBPLL) used for the data converters, digital filters and I/O ports. All the frequency signals are generated using these PLLs clock outputs.

All the PLLs require a reference clock input and for this there is the digitally controlled oscillator (DXCO) function, which is an in-chip programmable and variable capacitor, such capacitor can tune the crystal frequency variance before entering the system, having a precision of +/- 6 ppm it results in a more accurate reference clock and can be used, if needed, for synchronization purposes, this function can also be used together with the on-chip temperature

sensor to provide temperature compensation depending environment in which the chip will be used. For the reference clock there are two options:

#### **External Oscillator**

In this option and external clock signal can be connected in the XTALP pin (Leaving the XTALP pin unconnected), this external clock frequency may vary from 10 MHz to 80 MHz. Such type of setup is needed when a wireless basestation (BTS) reference clock is locked to a master clock, and in such systems there is no or less need for clock synchronization.

## **Dedicated Crystal**

In this option a dedicated crystal, with frequency varying from 19 MHz to 50 MHz, is connected in the XTALP and XTALN pins. This setup is usually used in wireless user equipment (UE), which do not need to be locked to a master clock but they do need to adjust periodically the LO frequency in order to maintain a connection with a BTS. The BTS periodically informs the UE of its frequency error relative to the BTS and the BBP can make adjustments to the reference clock and thus adjust the LO frequency if needed.



Figure 6.5: DCXO Behavior Graph

## **6.1.6** Synthesizers

#### **RF PLLs**

The AD9361 contains two identical synthesizers to generate the required LO signals for the RF signal path, one for the receiver and one for the transmitter. The PLL synthesizers are fractional-n PLLs with completely integrated VCOs and loop filters, requiring no other external components. In TDD operation mode, the synthesizers turn ON and OFF appropriate for the TX and RX frames, however in FDD TX PLL and RX PLL are activated at the same time.

#### **BB PLL**

The AD9361 contains also a baseband PLL synthesizer, which generate all the baseband related clock signals. The BBPLL feeds all the baseband related clock signals to ADC, DAC (Sampling Clock), DATA\_CLK signal and all data framing signals. This PLL has a frequency range from 700 Mhz to 1400 Mhz, and can be changed based on system requirements.



Figure 6.6: AD9361 PLL Reference Block Diagram

## 6.1.7 Digital Data Interface

The AD9361 uses parallel data ports to transfer data between the device and the BBP. These data ports can be configured either single-ended CMOS format or LVDS format (used in this work). Both formats can be configured in multiple arrangements to adequate the system requirements for data transfer and connections. These arrangements can be of single port data bus, dual port data bus, single data rate, double data rate and other various combinations compatible with the device.

Bus transfers are controlled using hardware handshake signalling, these two ports can be operated in TDD (bidirectional) or FDD (full duplex) where half of the bits are used for transmitting and the other half is used for receiving. The interface can also be configured to use only one of the data ports (usually used in applications that do not require high data rates or samples).

The communication between the BBP processor and the AD9361 rely on some signals to properly work, which are DATA\_CLK, FB\_CLK and RX\_FRAME, its operation is detailed below:

## DATA\_CLK Signal

RX sends the signal DATA\_CLK to the BBP, which can be used when receiving data. DATA\_CLK can be used to control data sampling time, which can be single data rate (data is captured on rising clock edge) or double data rate (data is captured on both rising and falling clock edges). This can be applied using single or dual data port.

## FB\_CLK Signal

The FB\_CLK signal must have the same frequency and duty cycle as DATA\_CLK and like DATA\_CLK it is used as timing reference for the interface. FB\_CLK allows source synchronous with rising edge capture for burst control signals and can be used like DATA\_CLK for rising edge, single data rate mode or in both edge capture, double data rate mode for transmit signal bursts.

## **RF\_FRAME Signal**

The RF\_FRAME signal is generated by the device whenever the receiver outputs valid data. RF\_FRAME has two modes:

• Level Mode: RF\_FRAME stays high as long as the data is valid.

• **Pulse Mode:** RF\_FRAME pulses with 30

The BBP must provide a TX\_FRAME that indicates beginning of a valid data transmission with a rising edge. The TX\_FRAME operates similarly as the RF\_FRAME, on Level Mode or Pulse Mode.

### **6.1.8** Enable State Machine

The AD9361 has an Enable State Machine (ENSM) which allows real-time control over the current state of the device. The device can be place in several states like:



Figure 6.7: AD9361 Digital Data Interface

• Wait: Power save, synthesizers disabled.

• Sleep: Wait with all clocks and BBPLLs disabled.

• TX: TX chain enabled.

• **RX:** RX chain enabled.

• **FDD:**TX and RX chains enabled.

• Alert: Synthesizers enabled.

This ENSM can be controlled either by SPI or PIN (GPIO for example), where the SPI control mode is for a non real-time operation and the PIN control mode is for a much faster and real-time control.

### **SPI Control Mode**

In SPI control mode, the BBP writes registers asynchronously by using SPI protocol to access the addresses, and by writing these registers the state machine advances the current state to the next state. SPI communication is considerece asynchronous to the DATA\_CLK because the SPI\_CLK can be derived from another clock source, where BBP

and the device does not share the same clock source. This control method is recommended when there is no need for a real-time control.

#### **Pin Control Mode**

In Pin control mode, there are pins dedicated to activate some states of the ENSM, like ENABLE pin and TXNRX pin, this mode allows a real-time control of the current state. This method is recommended in a system where the BBIC has extra pins to spare with the real-time control outputs, this 2-wire interface can control the state of the device. To advance the current state to the next state of the ENSM, the enable function of the ENABLE pin can be driven by either pulse or level, if the pulse is used the minimum width of the pulse needs to be equal as the FB\_CLK cycle. In FDD mode, the ENABLE and TXNRX pins can be remapped to be used as real-time control of the TX and RX data transfers. In this mode ENABLE enables or disables the receive signal and TXNRX enables or disables the transmit signal, using such mode causes the ENSM to be removed from the system for data flow control and is replaced by these pins.

### **6.1.9** SPI Interface

The AD9361 uses a SPI interface for communication with the BBP. Throught SPI is possible to access all the device registers. The PSI interface can be configured as a 4-wire interface with dedicated transmit and receive pins, duplex, or as 3-wire interface with bidirectional data port. Write commands have a 24-bit format where the first six bits are for setting the bus direction and number of bytes to transfer, the next 10 bits set the address where the data is to be written and the final eight bits are the data to be transferred to the specific register address (MSB to LSB), a LSB-first format is also supported. Read commands follow a similar format, the difference is that the first 16 bits are transferred on the SPI\_DI pin and the final eight are read from the AD9361, either using SPI\_DO (4-wire interface) or SPI\_DI (3-wire interface).

## **6.1.10** Auxiliary Converters

## **AUXADC**

The AD(361 contains an auxiliary ADC that can be used to monitor some system functions such as temperature or power output, it is a 12-bit converter and has an input range of 0V to 1.25V. The SPI can read the last value latched at the output of the ADC when



Figure 6.8: FDD Enable State Machine



Figure 6.9: TDD Enable State Machine

it is enabled for use, there is also a multiplexer that permits to select between AUXADC and built-in temperature sensor.

#### **AUXDAC1 and AUXDAC2**

The AD(361 also has two identical auxiliary DACs which can be used to provide power amplifier (PA) bias or other system functionality. Both the DACs are 10-bit wide and have an output range of 0.5 V to 0.3V and have a current drive of 10mA. The DACs can be directly controlled by the ENSM.

#### **6.1.11** Applications

## 6.2 FMCommS2

FMCommS2 is basically evaluation board for the AD9361 that has a FPGA Mezzanine Card (FMC) connector for interfacing with the BBP (Usually FPGA). The FMComms2 has 5 SMA connectors, 2 for Rx, 2 for Tx and one for external reference clock input. The FMComms2 provides a 2x2 RF configuration, extended from the AD9361, and has a narrow tuning range balun, which is performance optimized for 2.4GHz. The FMComms2 is a transceiver intended for use in RF applications such 3G or 4G BTS or SDR. Its programmability and wideband capability make it ideal for broad range of transceiver applications and make it very attractive for the new C-RAN paradigm.



Figure 6.10: FMComms2 and its components

#### **6.2.1** Functional Overview

The Block diagram show that there are 4 main functional partitions - receiver path, transmit path, clocking and power supply. Since the FMComms2 incorporates and extends the basic functionalities of the AD9361, thus the data path is fully integrated into the AD9361.



Figure 6.11: FMComms2 and FPGA Block Diagram

#### Receive

- Support up to 2 direct conversion RF receiver channels.
- Fully integrated frequency synthesizers (including loop filter).
- Data path consists in LNA, Demodulator, LPF, ADC and digital filters.
- AGC: quadrature calibration and DC offset calibration.
- NF: 2.5 dB at 1Ghz.
- ADC: Continuous time sigma-delta ( $\Sigma \Delta$ ), 640 MSPS.
- Digital FIlter: 128 COmplex taps with decimation between 2 and 48.
- Gain: 1dB step size, 80 dB analog Range, 30 db digital range (post ADC scaling).
- On-chip sensor for temperature corrected RSSI.

#### **Transmit**

- Supports up to 2 direct conversion RF transmit channels.
- Fully integrated frequency synthesizers (including loop filter).
- Data path consists of digital filters, DAC and modulators.
- Digital Filter: 128 complex taps with interpolation between 2 and 48.
- Gain: 0.5 dB step size, 86 dB range.
- ADC: 340 MSPS.

#### Clocking

The FMComms2 board has a integrated crystal oscillator of 40 Mhz and has a SMA input for external clock input.

#### **Control/Monitor**

The board allows real time control and monitoring via dedicated pins, such pins functionality are programmable. The control and monitor programming configuration is specified in the ad9361 section [?].

## **6.3** Basic Mathematical Background

## **6.3.1** Complex Modulation

$$I = \sin(\omega \times t) \tag{6.1}$$

$$Q = \cos(\omega \times t) \tag{6.2}$$

$$cos(\omega \times t) = sin(\frac{\pi}{2} - (\omega \times t))$$
(6.3)

then:

$$I = \sin(\omega \times t) \tag{6.4}$$

$$Q = \sin(\frac{\pi}{2} - (\omega \times t)) \tag{6.5}$$

These are the two signals coming out of the DAC, two sine waves, phase offset from each other, wich is called IQ.

#### **6.3.2** Basic Modulation Mathematics

Start to modulating signal from a amplitude perspective:

$$LO_I = A_x cos(k) (6.6)$$

$$LO_Q = B_x sin(k) (6.7)$$

We still have the carrier:

$$LO_I = cos(\omega); LO_Q = sin(\omega)$$
 (6.8)

Will result:

$$LO_I \times I = A_x cos(k) \times sin(\omega)$$
 (6.9)

$$LO_Q \times I = B_x sin(k) \times cos(\omega)$$
 (6.10)

That gives the output:

$$x(t) = A_x cos(k) \times sin(\omega) + B_x sin(k) \times cos(\omega)$$
(6.11)

This does not match with any trigonometrical identities and it is easier to use Eulerś formula:

$$sin(x) = \left(\frac{1}{2}e^{-jx} - \frac{1}{2}e^{jx}\right) \tag{6.12}$$

$$cos(x) = \left(\frac{1}{2}e^{-jx} + \frac{1}{2}e^{jx}\right) \tag{6.13}$$

Therefore:

$$x(t) = A_x(\frac{1}{2}e^{-jk} + \frac{1}{2}e^{jk}) \times (\frac{1}{2}e^{-j\omega} - \frac{1}{2}e^{j\omega}) + B_x(\frac{1}{2}e^{-jk} - \frac{1}{2}e^{jk}) \times (\frac{1}{2}e^{-j\omega} + \frac{1}{2}e^{j\omega})$$
(6.14)

$$x(t) = \frac{A}{2}(e^{-jk} + e^{jk}) \times (e^{-j\omega} - e^{j\omega}) + \frac{B}{2}(e^{-jk} - e^{jk}) \times (e^{-j\omega} + e^{j\omega})$$
 (6.15)

If we expand we get:

$$x(t) = \frac{1}{2} ((Ae^{-jk-j\omega} + Ae^{jk-j\omega} - Ae^{-jk+j\omega} - Ae^{jk+j\omega}) + (Be^{-jk-j\omega} - Be^{jk-j\omega} - Be^{-jk+j\omega} + Be^{jk+j\omega}))$$
(6.16)

And then:

$$x(t) = \frac{1}{2}((A+B)e^{-jk-j\omega} + (A-B)e^{jk-j\omega} - (A-B)e^{-jk+j\omega} - (A+B)e^{jk+j\omega})$$
 (6.17)

It is possible to rearrange as:

$$x(t) = \frac{1}{2} \times ((A+B)(e^{-jk-j\omega} - e^{jk+j\omega}) + (A-B)(e^{jk-j\omega} - e^{-jk+j\omega}))$$
(6.18)

And then:

$$x(t) = \left(\frac{A+B}{2}\right)\left(\sin(k+\omega)\right) + \left(\frac{A-B}{2}\right)\left(\sin(k-\omega)\right) \tag{6.19}$$

If this due to amplitude mismatch, this creates an image on the other side of the local oscillator.

## **FPGA**

- 7.1 ML605 Virtex6
- 7.2 VC707 Virtex7

## **Setup Description**

- 8.1 Overview
- 8.2 Integration between FPGA and FMComms2

## Part IV

**Final Results** 

## **Results**

- 9.1 Preliminary Tests
- 9.2 Transmission Tests

# Part V Conclusion and Future Work

Conclusion

## References

- [1] CENDRILLON, R.; GINIS, G.; DEN BOGAERT, E. V.; MOONEN, M. A near-optimal linear crosstalk precoder for downstream VDSL. *IEEE Transactions on Communications*, v. 55, p. 860–863, may 2007.
- [2] CIOFFI, J. Lecture notes for digital communication: Signal processing. Winter Quarter 2007-2008.
- [3] KLAUTAU, A. Digital communications adn signal processing: An introduction using octave or matlab. Now Publishers Inc, 2013.
- [4] GARDNER, F. M. Phaselock techniques. New York: Wiley, 1979.
- [5] JACOBSEN, K. S. Fundamentals of DSL technology. Auerbach Publications, 2006. Cap. 7.
- [6] MAXFIELD, C. *The design warrior's guide to fpgas: Devices, tools and flows.* Newnes, 2004. Cap. 1,2,3,4.
- [7] MALKIN, M. H. *Optimized transmitter-based signal processing for multicarrier systems.* jun. 2009. Tese (Doutorado) Stanford University, Stanford, USA, jun. 2009.
- [8] VAN DEN BRINK, R. F. Enabling 4GBB via the last copper drop of a hybrid FttH deployment. White paper on DSL, TNO, The Netherlands, apr. 2011.
- [9] Analog Devices. Ad9361 reference manual, 2015. Rev. A.
- [10] Analog Devices. Rf agile transceiver, 2014. Rev. E.
- [11] Analog Devices. Ad9361 device driver customization, 7 2015. Rev. 20 jul.
- [12] Xilinx. Vivado design suite user guide, 4 2014. Rev. 2014.2.

- [13] Xilinx. Getting started with the virtex-7 fpga vc707 evaluation kit, 10 2014. v. 1.4.1.
- [14] Xilinx. Logicore ip axi dma, 7 2012. v. 6.01.a.
- [15] Xilinx. Axi ethernet subsystem, 10 2014. v. 6.2.
- [16] INSTRUMENTS, T. Cd4007ub. site usar package url, 2012. original document from Harris Semiconductor.

## **Appendix A**

**PLL** 

## Appendix B

# **FPGA Design Flow**

# **Appendix C**

**PLL**