Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application ...

Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

# Development of libraries for radiofrequency instrumentation using FPGAs

N. Chrétien<sup>1,2</sup>, M. Lamothe<sup>1,2</sup>, G. Goavec-Mérou<sup>3</sup>, J.-M Friedt  $^2$ 

<sup>1</sup> Institut FEMTO-ST, Besançon

<sup>2</sup> Association Projet Aurore, Besançon

<sup>3</sup> Armadeus Project

Slides available at http://jmfriedt.free.fr

July 4, 2010

Chrétien, Lamothe, Goavec-Mérou, Friedt

Facts:

#### Introduction

- FPGAmicroprocesso communicatio
- A simple application ..
- Mémoire tampor sur un FPGA
- Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

## Introduction

- a general-purpose processing unit is unable to generate signals with frequencies above a few MHz (a few kHz when an OS is running)
- most signal processing tasks are complex to implement in low-level languages (assembly language, VHDL)
- using an operating system removes the need to waste time developing some basic tasks (scheduler, communication over a network, data storage, memory management ...)

Objective: complement a processor running an operating system with a software-reconfigurable electronc gate matrix array (FPGA), and hence get the best of both architectures.

application to reconfigurable radiofrequency instruments

#### Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocesso

A simple application ...

Mémoire tampor sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

# FEMTO time & frequency department

Provide instruments as support for the development of radiofrequency sensors

Flexibility of the software approach  $\Rightarrow$  developments on platforms combining a general purpose CPU and an FPGA:

- T. Rétornaz (frequency counter + camera), Armadeus APF9328 [1]
- T. Rétornaz (software defined radio), Ettus USRP [2]
- G. Goavec-Mérou<sup>1</sup> (xenomai and latency measurement using the FPGA), Armadeus APF9328 & APF27 [2]
- G. Goavec-Mérou (microsystem control), Armadeus APF27 [3]
- N. Chrétien (fast sampling/RADAR application), APF9328
- M. Lamothe (high resolution frequency counter), APF9328

[1] http://free-electrons.com/pub/video/2008/rmll [2] http://free-electrons.com/pub/video/2009/rmll

[3] dMEMS 2010, Besançon, France (2010),

Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application ...

Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

## Platform selection

- Opensource tools (or at least free of charge: Xilinx ISE)
- Processor running GNU/Linux
- User communauty, wiki & sample progam database
- Common busses (data/address) between the CPU and FPGA for efficient data sharing



- 1 presentation of IP management (VHDL) in the FPGA (POD)
- efficient communication between the CPU-FPGA (hardware aspects + software/ Linux kernel module)
- ③ practical applications

#### Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application .

Mémoire tampor sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

## The Wishbone bus

The Wishbone interface is a bus optimized for reconfigurable hardware (similar to the Avalon bus used by Altera) based on freely available specifications.

## Advantage of using the Wishbone bus:

- Rational communications FPGA-CPU communication
- Ease the addition of new IPs to an existing environment
- Opensource communication bus dedicated to FPGAs

## Components (VHDL) used for a functional bus:

- i.MX Wrapper: the microprocessor/FPGA interface,
- Syscon: CLK signal generation (directly provided by the i.MX CPU) and RESET (synchronous),
- Intercon: links all the components connected to the Wishbone system,
- Interrupt manager: interrupts sent to the CPU,
- Wishbone slaves: final application components.

Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application .

Mémoire tampor sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

### Bus structure:



## The Wishbone bus

◆□▶ ◆□▶ ◆∃▶ ◆∃▶ ∃ のへで

Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application .

Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

## Presentation of POD

"Peripherals On Demand"<sup>2</sup> is an opensource application, written in Python and developed by Armadeus Systems, helping the integration of virtual peripherals (components) in an FPGA

### Advantages of POD:

- uses external applications (Xilinx ISE, Altera Quartus) to generate the bitstream for configuring FPGA,
- multi-platform (Windows, Linux, MacOS).
- automatic generation of most mandatory components for using the Wishbone bus, in VHDL or Verilog,
- generates Linux driver templates,
- automated generation and connexion of multiple identical slave components (using different hardware input/outputs)

<sup>2</sup>http://www.armadeus.com/wiki/index.php?title=POD\_installation\_guide) < (>

Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application ...

Mémoire tampor sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

## Simple application

Blinking LED example to demonstrate the most basic aspects of communicating over the Wishbone bus:

- sending data from the CPU to the FPGA: defines how many times the LED blinks,
- sending data from the FPGA to the CPU: slave component identifier,
- using the FPGA input/outputs: digital input to trigger the continuous blinking of an LED connected to a digital ouput port.

Files needed in the project directory before launching POD:

- wb16.xml: configuration file used by POD,
- hdl/impulse.vhd : top file of the VHDL project,
- hdl/wishbone\_interface.vhd: link between the Intercon and the other slave components,
- hdl/diviseur.vhd: clock divider (generates a 2 Hz clock signal),
- hdl/gene\_impulse.vhd: LED command.

#### Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application ...

Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

# Demonstration

## Demonstration steps, under POD:

- project creation
- 2 automatic generation of the iMx.Wrapper and interrupt manager files
- **3** pin assignement
  - automatic Intercon file generation
- **5** automatic project top file generation
- 6 ISE project generation
- **7** TCL script generation
- 8 binary file generation to be loaded in the FPGA

## On the Armadeus platform:

- ssh and possibly NFS connections between a PC and the CPU,
- 2 load kernel module (communication with the FPGA),
- 3 transfer the binary configuration file to the FPGA,
- 4 read and write in the registers shared between the FPGA and the CPU.

Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application ...

Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

This file includes all the informations needed to generate the project. Mandatory items are:

- generics: the "generic" variables declared in the VHDL files (here the identifier of the component),
- hdl\_files: the VHDL files of the project, whose top file is associated to an additional argument (istop="1"),
- interfaces: the various input/outputs of the slave component, grouped as a subset,
- ports: the definitions of the ports used by the interfaces,
- registers: the registers, and their adresses, accessible by the CPU through the Wishbone bus.

Two interfaces are mandatory: candr (clock and reset) and swb16 (Wishbone signals). The only modifications to this file are:

- the "generic" variables to be added if needed,
- the files incuded in the project,
- the interface including the "external" input/output signals
- the registers of the swb16 interface

wb16.xml

```
Development of
  libraries for
 radiofrequency
                                                                                  wb16.xml
 instrumentation
  using FPGAs
              Sample of the file:
   Chrétien.
   Lamothe.
 Goavec-Mérou.
             8 <generics>
    Friedt
                      <generic name="id" public="true" value="1" match="\d+" type="natural" destination="both</pre>
                             " />
            10 </generics>
            12 < hdl files>
                  <hdl_file filename="impulse.vhd" scope="both" istop="1" />
communication 14
                  <hdl_file filename="gene_impulse.vhd" scope="both" />
                 <hdl_file filename="diviseur.vhd" scope="both" />
A simple
                  <hdl_file filename="wishbone_interface.vhd" scope="both" />
            16
application ...
                </hdl_files>
Mémoire tampor<sup>18</sup>
                <interfaces>
            20
                  <interface name="inpout" class="gls" >
                      <ports>
                      <port name="start" type="EXPORT" size="1" dir="in" />
                      <port name="impulse" type="EXPORT" size="1" dir="out" />
            24
                    </ports>
                  </interface>
Interrupt usage 26
                  <interface name="candr" class="clk_rst">
            28
                    <ports>
                      <port name="gls_reset" type="RST" size="1" dir="in" />
            30
                      <port name="gls_clk" type="CLK" size="1" dir="in" />
                    </ports>
            32
                  </interface>
            34
                  <interface clockandreset="candr" name="swb16" class="slave" bus="wishbone16" >
                    <registers>
            36
                      <register name="ADD_ID" offset="0x00" size="16" rows="1" />
                      <register name="RCOMPT" offset="0x01" size="16" rows="1" />
            38
                    </registers>
```

 $11 \, / \, 41$ 

#### Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application ...

Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

## wishbone\_interface.vhd

This entity includes the declaration of:

- the clock and reset signals,
- the Wishbone communication signals: addresses, distinct data writing and reading, control signals,
- the signals transmitted to the slave component, in our case, a single signal: the number of blinking periods of the LED.

The architecture mainly include two "process", one for reading and the other one for writing.

The modifications performed on this file are:

- declaring the variable entities to be provided to the subprograms of the component
- the included registers,
- the actions performed when read or write requests are made at a given offset (complying with the offsets defined in the wb16.xml file)
- loading the variables provided to the various sub-programs

```
Development of
  libraries for
 radiofrequency
                                                        wishbone interface vhd
 instrumentation
 using FPGAs
              File sample:
   Chrétien.
   Lamothe.
 Goavec-Mérou.
    Friedt
            30 Architecture wishbone arch of wishbone interface is
                                     : std_logic ;
            32 signal wb_write
                signal wb_read
                                     : std_logic ;
microprocessor 34 signal s_compt
                                     : std_logic_vector(15 downto 0);
                constant ADD_ID
                                     : std_logic_vector(1 downto 0) := "00"; --- identifiant
            36
               constant RCOMPT
                                     : std_logic_vector(1 downto 0) :="01";-nbr impulsions
A simple
application ...
            38begin
Mémoire tampor40 register reading process
                pread : process(gls_clk,gls_reset)
              begin
            42
                if (gls_reset = '1') then-si reset
            44
                    wb_read <= '0':
                    wbs_readdata <= (others => '0');
            46
                elsif(rising_edge(gls_clk)) then - si horloge
                    wb_read \leq = '0':
            48
                    wbs_readdata <= (others => '0');
                    if (wbs_strobe = '1' and wbs_write = '0' and wbs_cycle = '1') then --- si lecture
                        wb_read <= '1':
            50
                        case wbs_addresse is
                          when ADD_ID \Rightarrow
            52
                             wbs_readdata <= std_logic_vector(to_unsigned(id,16)); ---identifiant dans readdata
            54
                          when others \Rightarrow
                        end case:
            56
                       end if:
            58
                end if:
                end process pread:
                                                                             イロト イヨト イヨト イヨト
```

Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

#### FPGAmicroprocessor communication

A simple application ...

#### Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

## Buffer memories

ヘロト 人間ト 人間ト 人間ト

14/41

How to continuously transfer data from the FPGA to the ARM9 CPU ?

- implement a buffer memory on the FPGA compatible with POD,
- fetch from Linux the data recorded in the FPGA,
- use of interrupts to optimize the data flow,
- application to the implementation of a frequency counter,
- the limits of the Wishbone bus.

Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application .

#### Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

# Xilinx Spartan3 FPGA architecture

- The Spartan 3 XC3S200:
  - 12 physical RAM blocks,
  - double port RAMs,
  - a total of 216 Kb RAM,
  - maximum clock speed 200 MHz.



Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application ..

#### Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

## Double port RAM

- Read and write address busses are **separate** in a double port RAM.
- Ability to **simultaneously** read and write at different addresses (cases 3 & 4) ...
- ... or to access as a classical single-port RAM (cases 1 & 2)  $^3$



Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application ..

#### Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

# RAM declaration (VHDL)

- Hardware resources on the FPGA are defined in a library:
- Library UNISIM; Use UNISIM.vcomponents.all;
- In order to use a RAM, import its entity (*VHDL declaration of the component*).
- In ISE: Edit >> Language Templates.



Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application ...

#### Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

## Wishbone address structure



Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application .

#### Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-samplin rate

Conclusion

# A buffer memory compatible with POD



Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application .

#### Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

# An FPGA is a digital electronic component (problem)



Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application .

#### Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

# An FPGA is a digital electronic component (solution)



Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application ...

Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

## User space, kernel space

・ロト ・回ト ・ヨト ・ヨト

22 / 41

- User space is protected, and accessing peripherals is restricted,
- kernel space allows access to all peripherals and hardware resources.



The kernel module (driver) provides a link between user space and kernel space.

Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application ...

Mémoire tampor sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

# The ioread16 function (kernel space)

## Communication between the FPGA and the CPU

The ioread16() function reads the status of the peripheral:

```
Istatic struct plat_led_port plat_led00_data = {
    .name = "plat_led",
    .name=00,
    .membase = (void •)(ARMADEUS_FPGA_BASE_ADDR_VIRT + 0x800),
    [...]
    .data = ioread16(g_current->membase+i_addr);
7}
```

writes the address of the requested peripheral on the Wishbone address bus and returns the 16-bit value read on the data bus.

Chrétien, Lamothe, Goavec-Mérou, Friedt

# The read() function (kernel module)

#### Introduction FPGAmicroprocessor communication between the kernel and user space (Linux) A simple application ... A simple application ... A simple application ... A simple application ... Fhe read() function is one of the basic methods of the module: Mémoir tampon sur un FPGA function is one of the basic methods of the module: Mémoir tampon sur un FPGA function is one of the basic methods of the module: Mémoir tampon sur un FPGA function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the module: function is one of the basic methods of the basic met

Application: GHz-sampling rate

Conclusion

- buff: array provided from user space,
- valeur: data array the driver sends back to the user through buff,
- count: number of bytes requested (provided from user space).

Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

### In the user space program:

```
Communication

Iunsigned char j[512];

A simple

application... 3[...]

read(fled,j,512);

Mémoire tampon5s = (unsigned short●)j;

sur un FPCA

for (i=0;i <=255;i++) fprintf(mFile1,"%d",s[i]);
```

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

# read() usage example (user space)

### The read() function requires:

- fled: file descriptor to the device driver acting as communication point between user and kernel spaces (points to /dev/XXX),
- j: character array in which the module returns the values
- 512: number of bytes to be transfered (RAM=256\*16 bits).

Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application ...

Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

# • In order to optimize the data exchange between the FPGA and the Linux driver, use of interrupts to notify the module of the availability of data.

- when the FPGA has completed filling a RAM, trigger an interrupt to wake up the Linux module
- avoid locking the Linux system, efficient data transfer since the CPU reads data from one RAM as the FPGA writes in an other.



Make sure the interrupt rate is low enough to avoid locking the Linux system (depends on processing load)

Interrupts

Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application ..

Mémoire tampor sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

## Code example

### In the init() function of the module:

request\_irq(IRQ\_GPIOA(4),button\_interrupt,0, sdev->name,sdev); set\_irq\_type(IRQ\_GPIOA(4), IRQF\_TRIGGER\_RISING);

### In the request\_irq() function:

• IRQ\_GPIOA(4):

declares the pin associated to the interrupt request (pin 4 of port A),

• button\_interrupt:

interrupt service routine called upon interrupt trigger.

set\_irq\_type declares the sensitivity of the interrupt (rising edge signal on pin 4 of port A)

#### Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocess

A simple application ...

Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

## Triggering an interrupt cleares the semaphore: up(&sema);

down\_interruptible(&sema);



A module sleeps as long as the semaphore has not been cleared

## Semaphores

(ロ)、(部)、(E)、(E)、E)の(で 28/41

Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application ..

Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

#### Application

Application: GHz-sampling rate

Conclusion

## Frequency counter principle

- Frequency is the physical quantity measured with the greatest accuracy
- FEMTO-ST time & frequency department is specialized in the development of high stability oscillator for source and sensor applications: the frequency counter is our basic measurement tool.



Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application ..

Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

#### Application

Application: GHz-sampling rate

Conclusion

## Experimental test setup

- the FPGA counts clock cycles (real time part)
- the ARM9 CPU collects data from the FPGA and manages data storage and transfer to the PC
- the frequency counter and the FPGA share the same reference clock



## Frequency calculation

#### Chrétien. Lamothe. Goavec-Mérou. Friedt

The frequency is *continuously* recorded at a rate of 128 samples/s (8 ms gate time)



#### Application



sample number

ヘロト 人間ト 人間ト 人間ト Э 31/41

Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGA-

A simple

Mémoire tampo sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usag

#### Application

Application: GHz-sampling rate

Conclusion

# Sliding average on contiguous samples

# Blue: commercial HP 53131A frequency counter, red: FPGA implementation of a reciprocal counter.



 $\rightarrow$  our measurements are consistent with the results of the (reference) commercial instrument

## Allan deviation

Chrétien, Lamothe, Goavec-Mérou, Friedt

Statistical analysis of an oscillator stability (standard deviation on variable width windows)

#### Introduction

FPGAmicroprocessor communication

A simple application ..

Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

#### Application

Application: GHz-sampling rate

Conclusion



### HP53131A

## FPGA implementation

- Statistical analysis confirmation of the equivalent results: in both cases the relative stability  $\Delta f/f \simeq 2 \times 10^{-9}$  at 1 s integration time
  - The short gate time of the FPGA implementation provides results down to  $\tau = 10$  ms (impossible to achieve using HP53131A)

Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application ..

Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

#### Application

Application: GHz-sampling rate

Conclusion

## Wishbone bus limitation

The Wishbone bus provides a restricted address bus width  $\Rightarrow$  reduced amount of addressable RAM

### Maxium of 9 bits $\Rightarrow$ 512 accessible addresses.



• We know we want to sequentially read the content of all RAM: no need to individually address each register.

Replace a dedicated address bus with a counter in the FPGA, incremented at each read step
 ⇒ the address bus is free to point to 1024 RAM blocks
 ⇒ strategy similar to DMA (no need to individually point to each memory register)

Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application ..

Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

# Radiofrequency sampling rate: objectives

- The objective is the sampling of ultrasonic and RADAR (GPR) echo signals at rates above the GHz range (practical demonstration: 4 Gsamples/s) ...
- ... under the assumption of a stationary signal (the probed medium does not significantly change between measurements) ...

- ... in order to use an appropriate method: *Equivalent Time Sampling*.
- acoustic and electromagnetic charaterization of passive media probed by series of pulses.

## Equivalent Time Sampling

Principle: in this example, 10 samples are gathered over 1 period at sampling dates  $N \times \delta t$  (N = [1..10]), yielding an equivalent sampling

 $_{\text{Goavec-Mérou,}}$  sampling  $_{\text{Friedt}}$  rate  $1/\delta t$ 

### Friedt Introduction

Development of libraries for radiofrequency

instrumentation using FPGAs

> Chrétien, Lamothe.

FPGAmicroprocessor communicatior

A simple application .

Mémoire tampor sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion



Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application ...

Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

# **ETS**: implementation

### Needed hardware:

- fast A/D converter (low jitter): digitization of a voltage memorized by an externally triggered Sample & Hold (Linear Technology LTC1407),
- sub-ns delay generator (programmable delay line): time delay of the digital signal triggering the Sample & Hold (δt steps), Dallas/Maxim DS1023
- Control and synchronization system: provides all components the necessary signals (delay line programming, communication clocks ...)
- data retrieval and storage: low latency constraints compared to the Control system

Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application .

Mémoire tampo sur un FPGA

Sharing data between the FPGA and th ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

# Working principle



・ロト・(中・・ヨ・・ヨ・ つへぐ)

Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application .

Mémoire tampoi sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

# Application to recording ultrasonic echos (non-destructive testing)



## Obtained results



・ロト・日本・日本・ 日本・ うんの

#### Chrétien, Lamothe, Goavec-Mérou, Friedt

#### Introduction

FPGAmicroprocessor communication

A simple application ...

Mémoire tampon sur un FPGA

Sharing data between the FPGA and the ARM9 CPU

Interrupt usage

Application

Application: GHz-sampling rate

Conclusion

## Conclusion

- Architecture selection justification: complementarity of the general purpose CPU running an operating system + FPGA
- Practical demonstration of the development cycle
  - POD + Wishbone bus for a rational framework to communicate with multiple IPs in the FPGA
  - efficient communication between the CPU and the FPGA
- Experimental results of applications:
  - radiofrequency counters with performances in agreement with the commercial HP53131A (433/16 MHz input signal)
  - high frequency probe non-destructive testing and RADAR