

# REX Red Pitaya ADC-DAC démo & Echo Ethernet

Red Pitaya 125-14 STEMlabBoard

Fabrice Wiotte  
[fabrice.wiotte@univ-paris13.fr](mailto:fabrice.wiotte@univ-paris13.fr)

Laboratoire de physique des lasers  
**Université Sorbonne Paris Nord**

# Sommaire

1. Présentation Red STEMlab Board : .....page 3 à 7
2. Objectifs démo RedPitaya.....page 8
3. TP démo RedPitaya.....page 10 à 73
  - 3.1 Bloc Design moteur pas à pas .....page 9
  - 3.2 Environnement de développement VIVADO.....page 9
  - 3.3 Script Python pour Echo Ethernet.....page 74 à 76
  - 3.4 Communication serial Port COM Redpitaya avec Putty ..page 76
  - 3.5 Test\_bench frequency\_modulation@125KHz .....page 77
  - 3.6 Calcul des points du module VHDL frequency\_modulation
    1. Avec Excel .....page 77
    2. Avec Matlab .....page 78

Présentation de la Red STEMlab Board :

## Introduction

La RedPitaya est une carte FPGA « bas coût », une carte de développement comme Arduino ou Raspberry Pi. La particularité de cette carte est sa capacité de gérer des signaux rapides jusqu'à 50MHz. La carte peut être utilisée rapidement avec les applications disponibles, ou peut être exploitée comme une plate-forme ouverte. Il est possible de l'adapter à un grand nombre de projets nécessitant un contrôle rapide et performant comme du traitement de signal ou de la radio logicielle.

C'est une plate-forme d'acquisition et de génération de signaux RF de la taille d'une carte de crédit. La carte est basée sur un système sur puce SOC — FPGA de la gamme Xilinx Zynq qui permet de combiner la capacité de programmation d'un cœur ARM Cortex-A9 à double cœur (LINUX embarqué).

## Schéma de principe et architecture

L'instrument est équipé de deux entrées et deux sorties analogiques RF (125 MS/s). Différentes résolutions sont proposées (10,14 ou 16 bits), quatre entrées et quatre sorties analogiques (100 kS/s), ainsi que de 16 ports entrés/sorties logiques universels. Coté connectivité, nous pouvons compter sur un port ETHERNET 1 Gbit, un port USB 2.0 et autres protocoles (I2C, SPI, UART), le tout peut être autonome grâce à la carte SD.

Pour le soft la carte est basée sur le système d'exploitation GNU/Linux. Possibilité d'intégration dans son propre système/produit, elle peut être programmée avec différents niveaux avec une variété d'interfaces logicielles, les langages de programmation sont : HDL/Verilog, C/C++, Python/Jupyter, et un serveur web intégré (NGINX) pour des interfaces web basées sur HTML/JavaScript. Elle peut être utilisé comme oscilloscope et générateur de signaux, spectre, analyseur de Bode, analyseur logique, compteur LCR\*, streaming, SDR ou analyseur de réseau vectoriel\* grâce à l'écosystème fourni par STEMlab.

On peut également utiliser **PyRPL** (Python Red Pitaya Lockbox), un progiciel open source en Python pour les expériences d'optique quantique contrôlées par FPGA avec des applications disponibles : Lock-in Amplifiers, PID...

STEMlab Board 125-14 :



Liens utiles sur le site Red Pitaya STEMlab :

<https://redpitaya.com/stemlab-125-14/>

[https://redpitaya.com/rtd-  
iframe/?iframe=https://redpitaya.readthedocs.io/en/latest/developerGuide/har  
dware.html](https://redpitaya.com/rtd-iframe/?iframe=https://redpitaya.readthedocs.io/en/latest/developerGuide/hardware.html)

<https://redpitaya.com/applications-measurement-tool/fpga/>

[https://redpitaya.readthedocs.io/en/latest/developerGuide/software/build/fpga/  
fpga.html](https://redpitaya.readthedocs.io/en/latest/developerGuide/software/build/fpga/fpga.html)

-> Quick Start

-> Developers guide -> Hardware  
-> Software

STEMlab Board 125-10 versus STEMlab Board 125-14:

|                            | <b>STEMlab 125-10</b>             | <b>STEMlab 125-14</b>            |
|----------------------------|-----------------------------------|----------------------------------|
| <b>Basic</b>               | Processor                         | Dual Core ARM Cortex A9          |
|                            | FPGA                              | Xilinx Zynq 7010 SOC             |
|                            | RAM                               | 256 MB (2 Gb)                    |
|                            | System memory                     | Micro SD up to 32 GB             |
|                            | Console connection                | USB to serial converter required |
|                            | Power connector                   | Micro USB                        |
|                            | Power connector                   | Micro USB                        |
|                            | Power consumption                 | 5 V, 1,5 A max                   |
| <b>Connectivity</b>        | Ethernet                          | 1 Gbit                           |
|                            | USB                               | USB 2.0                          |
|                            | WiFi                              | requires WiFi dongle             |
|                            | Synchronisation                   | -                                |
| <b>RF inputs</b>           | RF input channels                 | 2                                |
|                            | Sample rate                       | 125 MS/s                         |
|                            | ADC resolution                    | 10 bit                           |
|                            | Input impedance                   | 1 MOhm / 10 pF                   |
|                            | Full scale voltage range          | +/-20 V                          |
|                            | Absolute max. Input voltage range | 30 V                             |
|                            | Input ESD protection              | Yes                              |
|                            | Overload protection               | Protection diodes                |
| <b>RF outputs</b>          | RF output channels                | 2                                |
|                            | Sample rate                       | 125 MS/s                         |
|                            | DAC resolution                    | 10 bit                           |
|                            | Load impedance                    | 50 Ohm                           |
|                            | Voltage range                     | +/-1 V                           |
|                            | Output slew rate                  | 200 V/us                         |
|                            | Short circuit protection          | Yes                              |
|                            | Connector type                    | SMA                              |
| <b>Extension connector</b> | Digital IOs                       | 16                               |
|                            | Analog inputs                     | 4                                |
|                            | Analog inputs voltage range       | 0-3,5 V                          |
|                            | Sample rate                       | 100 kS/s                         |
|                            | Resolution                        | 12 bit                           |
|                            | Analog outputs                    | 4                                |
|                            | Analog outputs voltage range      | 0-1,8 V                          |
|                            | Communication interfaces          | I <sup>2</sup> C, SPI, UART      |
|                            | Dimensions                        | 107 x 60 x 21 mm                 |

ADC :  
LTC2145-14

DAC  
LTC2145-14

## STEMlab Board : Accès mode local ou adresse IP



Ecosystème installé sur la carte SD :

Accès local RP-F\*\*\*LOCAL/



## Accès distant adresse IP



Oscilloscope :



## 1. Objectif du TP :

Prendre en main et programmer la RedPitaya avec Vivado « bare metal »,  
*C'est à dire sans la carte SD insérée.*

La Red Pitaya dispose de 2 interfaces de programmation :

- 1) Une prise micro USB avec une puce FTDI derrière (nommée CON) à l'arrière de la carte.
- 2) Une interface JTAG (pin header nommé JTAG) sur la face avant.

Nous allons utiliser un **câble USB-JTAG Xilinx HS2** pour :

- 1) Programmer sous Vivado 2022\_2 le HARDWARE- > ADC-DAC et IP maison
- 2) Programmer le SOFTWARE avec Vitis 2022\_2-> Exemple Echo Ethernet.
- 3) Créer un fichier BOOT.bin sur carte SD pour la sauvegarde du programme.
- 4) Utiliser une carte fille développée pour la RedPitaya qui permet une entrée d'horloge externe pour la synchronisation.

Carte fille sur RedPitaya 125\_14 with external Clock



3. Demo RedPitaya sous Vivado 2022\_2

### 3.1 Bloc design du TP Demo RedPitaya sous Vivado 2022\_2



Vue d'ensemble Demo RedPitaya sous Vivado 2022\_2

## 3.2 Environnement de développement Xilinx (VIVADO)

3.3 Crédit du projet sous Vivado\_2022\_2 :

Lancer Vivado 2022.2-> File->Project->New->Create new Vivado project-> Next.



Create new Vivado project-> project name-> Next.



Ici je nomme le projet Red\_Pitaya\_125\_14\_demo\_ANF\_2023

Dans le répertoire Xilinx je créer un dossier-> TP\_VIVADO\_2022\_2

## Sélectionner « RTL Project » pour « Projet Type » puis « Next »



Dans Add Sources et Add Constraint-> On ne spécifie rien-> sélectionner-> Next



La board Redpitaya n'est pas présente par défaut dans Vivado :

Allez sur le lien ci-dessous pour récupérer redpitaya-125-14/1.0

[https://github.com/fabzz60/demo\\_adc\\_dac\\_Redpitaya\\_125\\_14](https://github.com/fabzz60/demo_adc_dac_Redpitaya_125_14)

Copier /coller le dossier board\_files/redpitaya-125-14/1.0 dont on a besoin dans C:\Xilinx\Vivado\2022.2\data\boards redémarrer Vivado.



Dans la fenêtre « **Default Part** », sélectionner « **Boards** », puis redpitaya-125-14 dans l'onglet « **Display Name** ». Appuyer sur « **Next** »



Dans la fenêtre « New Project Summary », cliquez sur « Finish » :



L'environnement de Vivado est lancé.



Nous allons récupérer la bibliothèque IP Redpitaya-125-14

[https://github.com/fabzz60/demo\\_adc\\_dac\\_Redpitaya\\_125\\_14](https://github.com/fabzz60/demo_adc_dac_Redpitaya_125_14)

Copier-coller le dossier [IPs\\_adc\\_dac\\_redpitaya\\_125\\_14](#) dans le répertoire source de votre projet, pour moi c'est :

C:\Xilinx\TP\_VIVADO\_2022\_2\Red\_Pitaya\_125\_14\_demo\_ANF\_2023

Dans l'onglet PROJECT MANAGER-> Settings -> IP Repository-> clic sur +-> ajouter le dossier : IPs\_adc\_dac\_redpitaya\_125\_14



Dans l'onglet IP Repository-> Select-> IP\_adc\_dac\_redpitaya\_125\_14-> Select.



Dossier IPs\_adc\_dac\_redpitaya\_125\_14 ajouté

Dans Settings-> sélectionner Apply puis « OK »



### **Création du block design :**

Dans la fenêtre “**Flow Navigator**” de Vivado à gauche de l’écran, cliquez sur « Create Block Design » de la rubrique « IP Integrator », remplacer le nom donné par défaut au block design par Red\_Pitaya\_demo



Puis « OK »



On va insérer les IP Processeur Zynq et Processeur Reset, ainsi que les IPs\_adc\_dac\_redpitaya\_125\_14 sur le Diagram :

- Le Processeur Zynq (Système de traitement ZYNQ7)
- Le Processeur Reset (Réinitialisation du système du processeur)

- **AXIGPIO** (L'AXI GPIO fournit une interface d'entrée/sortie à usage général) l'interface AXI)
- **Redpitaya-125-14-clk**
- **Redpitaya-125-14-adc** (les échantillons ADC 14 bits sont alignés MSB dans les interfaces de flux AXI 16 bits sortantes)
- **Redpitaya-125-14-dac** (les échantillons DAC 14 bits sont extraits du MSB des interfaces de flux AXI 16 bits entrantes)



Dans Diagram -> clic sur + tapez dans la barre de recherche -> Zynq



Touche entrée -> le processeur apparaît sur le Diagram



## Clic sur Run Block Automation-> puis « OK »



Dans **Diagram** -> clic sur + tapez dans la barre de recherche -> **processor system reset**



Touche **entrée** -> le processeur system reset apparait sur le Diagram



Dans Run Connection Automation-> sélectionnez ext\_reset\_in et new Clocking Wizard-> puis « OK »



Dans **Diagram** -> clic sur + tapez dans la barre de recherche -> **AXI GPIO**



Dans PROJECT MANAGER-> IP Catalog-> sélectionnez User\_Repository-> Add IP to Block Design / On ajoute les trois IP sur le Block Design



Les IP ADC DAC et CLK apparaissent



Nous utilisons `clk_125`, qui fonctionne à 125 MHz, pour piloter la logique principale de la conception. Tous les chemins de données de ce didacticiel seront synchrones avec cette horloge. Connectez les horloges et les réinitialisations comme indiqué dans le Diagramme ci-dessous.



Configurez l'AXI GPIO pour avoir une sortie 4 bits qui correspond aux Leds de la RedPitaya que l'on va utiliser pour tester l'Echo Ethernet

### Double clic sur AXI\_gpio\_0



Sélectionnez GPIO et GPIO Width = 4 puis « OK »



Clic sur Run Connection Automation-> puis « OK »



Il nous reste à câbler manuellement comme ci-dessous les lignes d'horloges.



Nous allons importer les IP « maison » du projet : récupérer **divide\_clock.vhd**

**Frequency\_modulation.vhd**, **leds.vhd**, **Select\_in\_data.vhd** avec le lien ci-dessous : [https://github.com/fabzz60/demo\\_adc\\_dac\\_Redpitaya\\_125\\_14](https://github.com/fabzz60/demo_adc_dac_Redpitaya_125_14)

Copier-coller dans le répertoire du projet.



Nous allons les intégrer à notre projet dans le Diagram RedPitaya\_demo

Dans **BLOCK DESIGN-> clic sur + -> Add or create sources.**



## On sélectionne les fichiers VHDL puis « OK »



## Puis « Finish »



## Clic droit sur chaque fichier VHDL puis-> Add Module to Block Design



## Les modules insérés sur le Diagram du projet



Nous allons ajouter une IP Xilinx DDS dans le projet : DDS Compiler puis-> touche entrée



IP ajouté



Double clic sur l'IP DDS Compiler : on configurer l'IP pour générer une modulation de fréquence de 125KHz-> dans configuration-> sélectionnez comme ci-dessous



Dans implementation-> sélectionnez comme ci-dessous



Dans Output Frequencies-> sélectionnez comme ci-dessous



Dans Summary-> On vérifie que l'on génère un signal @125KHz sur 16bits



Pour finir il nous faut câbler manuellement les modules VHDL insérés comme ci-dessous : nous allons utiliser les ADC et DAC de la RedPitaya avec les IP « maison » développées en VHDL.

### Rôle des IP « maison » :

Le module **select\_in\_data** : permet de sélectionner les signaux d'entrées des deux DAC. Deux BP sur la carte fille permettent la sélection des data-> Les signaux sont issus des ADC1 et ADC2 ou des IP internes **Frequency\_modulation** et **DDS\_Compiler**.

Le module **divide\_clock** : permet de diviser l'horloge@125MHz vers 1Hz et visualisé sur des Leds de la carte fille.

Le module **Leds** : Gérer les Leds de la RedPitaya.

Relier les modules comme ci-dessous :



Enfin il faut câbler les ports d'entrées-sorties :

Par exemple on se place sur l'entrée `adc_clk_n_i` : clic droit puis

**Create Port** (Ctrl + K) ou **Make External** (ctrl + T).

Attention seul **Create Port** vous permet de renommer la broche.

Faire de même pour toutes les autres entrées-sorties.

## Zoom sur le Diagram



## Vue complète Vivado :



Pour finir nous allons modifier la sortie de axi\_gpio\_0 comme ci-dessous :



Renommer la sortie : leds\_GPIO\_zynq



## Le module AXI GPIO et sa sortie sur 4 bits



On agence automatiquement le Design



## On valide le Diagram



## Création du HDL Wrapper :

Dans l'onglet Sources /Hierarchy du BLOCK DESIGN « Red\_Pitaya\_demo », clic droit et sélectionnez « Generate Outputs Products », « Generate » puis « OK »



## Generate Outputs Products ...



Dans l'onglet « Red\_Pitaya\_demo », clic droit et sélectionnez « Create HDL Wrapper » :



Let vivado manage wrapper... puis-> OK.



## Wrapper crée !



## Arborescence complète !



## Ajout ou création d'un fichier de contrainte :

Dans PROJECT MANAGER-> Sélectionnez dans Add Sources-> « Add or create constraints »-> Next>



Nous allons récupérer le fichier de contrainte dans le dossier source du projet : CmodA7.xdc : Sélectionnez redpitaya.xdc puis « OK »

[https://github.com/fabzz60/demo\\_adc\\_dac\\_Redpitaya\\_125\\_14](https://github.com/fabzz60/demo_adc_dac_Redpitaya_125_14)

Add or Create Constraints-> Add Files-> Next.



Sélectionnez redpitaya.xdc puis « OK »



Finish...



Le fichier de contrainte apparaît dans **BLOCK DESIGN**-> sous l'onglet **Sources**-> **Constraints**. Clic droit sur le fichier de contrainte et définir comme la cible principale-> » Set as target constraint file ».



## On lance la synthèse-> touche F11

Save...



Clic sur « OK »



On ouvre l'implémentation :



## Implémentation...

Dans l'onglet Windows-> I/O Ports



On vérifie et on édite si nécessaire les I/O :



Vérification par rapport au fichier de contrainte redpitaya.xdc



On fait une sauvegarde pour une mise à jour du fichier de contrainte :  
CmodA7.xdc-> **CTRL + S**

Dans Flow Navigator-> Run Implementation



## Générer le bit file pour programmer la cible FPGA partie HARDWARE



Launch Runs-> « OK »



Bitstream OK



Dans Flow Navigator-> Open Hardware Manager-> Open Target-> Auto connect.

## A ce stade on ne programme que le HARDWARE via le câble JTAG-USB.



## Open Target-> Auto connect.



## Hardware Manager-> Program Device->Program



Dans l'onglet Program Device vérifier le nom et le chemin du projet...

On ferme HARDWARE MANAGER-> clic sur « OK »



**Important :** Avec la programmation du bit file sur vivado :

On peut vérifier sur la carte RedPitaya le fonctionnement des ADC-DAC avec les fréquences générées par l'IP DDS Compiler et l'IP maison frequency\_modulation

en utilisant les boutons poussoirs. On visualise également l'état des leds (leds\_redpitaya [3 :0]) cadencés@1Hz sur la carte fille, et les leds sur la carte RedPitaya (leds\_GPIO\_zynq [3 :0]) cadencés également @1Hz.

Fonctionnement de la carte Redpitaya 125\_14 après chargement du programme



Fréquences générées par l'IP DDS et l'IP maison @125KHz



Exporter vers VITIS le projet VIVADO 2022.2

Menu principal-> File-> Export-> Export Hardware



## Next...



Export Hardware-> Include bitstream-> Next.



Next...



Finish



On lance VITIS 2022\_2  
Menu Tools-> Launch Vitis IDE



Launch Vitis...



## Environnement Vitis



Projets déjà existants...

Dans Menu Principal->File->New-> Platform Project



Rename the project-> **redpitaya\_ANF**-> Next.



Dans Create a new platform hardware (XSA)-> Browse...



Clic sur-> Finish



Platform : **redpitaya\_ANF**



## Menu principal->File-> New-> Application Project



Next...



Select a platform from repository-> Redpitaya\_ANF [custom]-> Next.



Application project name = **redpitaya\_ANF2023**-> Next



Domain = `standalone_domain` -> Next



New Application Project -> LwIP Echo Server

La librairie n'est pas active par défaut dans le projet : on doit revenir dans le BSP

Pour activer lwIP Echo Server : donc faire Cancel



Double clic sur-> platform.spr sous la plateforme : redpitaya\_ANF et sous standalone\_on\_ps7\_cortexa9\_0-> Board Support Package Settings



Selectionnez la librairie lwip211 puis clic sur « OK »



On retrouve installé la librairie **lwp211\_v1\_8**



On enregistre la platform redpitaya\_ANF-> Clic droit sur **redpitaya\_ANF-> Build Project**



On reprend la précédente procédure : Menu principal->File-> New-> Application Project



Select a platform from repository-> Redpitaya\_ANF [custom]-> Next.



Application project name = **redpitaya\_ANF2023-> Next**



Domain = **standalone\_domain-> Next**



## Sélectionnez lwIP Echo Server puis Finish



Le projet complet : En vert la platform HARDWARE en rouge la partie SOFTWARE  
Zynq avec l'exemple Echo Ethernet



On va modifier les fichiers sources du programme : main.c et echo.c et insérer deux nouveaux fichiers : leds\_RGB.c Led\_RGB.h au projet pour la gestion et la communication avec les leds de la RedPitaya en Ethernet.



Fermer VITIS 2022\_2 !

Télécharger les fichiers main.c, leds\_RGB.c, leds.RGB.h, echo.c avec le lien

[https://github.com/fabzz60/demo\\_adc\\_dac\\_Redpitaya\\_125\\_14](https://github.com/fabzz60/demo_adc_dac_Redpitaya_125_14)

Copier- coller dans le répertoire du projet Vitis les fichiers ci-dessus :

Le chemin d'accès devrait ressembler à ceci :

C:\Xilinx\TP\_VIVADO\_2022\_2\Projets\_VITIS\_2022\redpitaya\_ANF2023\src



Sauvegarder: Ctrl +SHIFT + S puis clic droit sur redpitaya\_ANF2023\_system-> Build Project

Dans le main.c On vérifie l'adresse IP et l'adresse MAC de la redpitaya

```

Projects_Vitis_2022 - redpitaya_ANF2023/soc/main.c - Vitis IDE
File Edit Search Run Xilinx Project Window Help
Explorer > zynq_fsl
    > zynq_ip
        > platform.tcl
    > redpitaya_ANF2023/system | redpitaya_ANF [ ]
        > Binaries
        > Includes
        > Debug
        > echo.c
        > i2c_access.c
        > led_RGB.c
        > led_RGB.h
        > main.c
        > platform_config.h
        > platform_mb.c
        > platform_zynq.c
        > platform.c
        > platform.h
        > xps_5324.c
        > README.txt
        > Xilinx.spe
        > redpitaya_ANF2023.prj
        > _ide
        > Debug
            > sd_card
                > makefile
            > redpitaya_ANF2023_system_Debug.build.ui.log
            > system.kf
            > writebf.log
        > redpitaya_ANF2023_system.spj
    > redpitaya_demo
        > redpitaya_system | redpitaya_demo |
            > a7_motor
            > a7_motor_nevya_A7_system
            > stepper_motor
            > stepper_motor_board_GFF_nevya_A7
            > stepper_motor_board_GFF_system
    > _ide
    > redpitaya_ANF2023_system [System]
        > redpitaya_ANF2023 [Application]

```

```

124     {
125         if(LWIP_IPV4==0)
126             ip_addr_t _ipaddr, netmask, gw;
127
128         /* If the mac address of the board, this should be unique per board */
129         /* unsigned char mac_etherenet_address[] = */
130         /* { 0x00, 0x26, 0x32, 0x00, 0x90, 0xfa }; //address MAC redpitaya */
131
132         /*endif*/
133         echo_netif = &server_netif;
134         if(XPAR_GIGE_PCS_PMA_SGMII_CORE_PRESENT == 1 || XPAR_GIGE_PCS_PMA_1000BASEX_CORE_PRESENT == 1)
135             ProgramS5324();
136             ProgramSgphy();
137
138         /*endif*/
139
140         /* Define this board specific macro in order perform PHY reset on ZCU102 */
141 #ifndef XPS_BOARD_ZCU102
142         if((XPS_BOARD_ZCU102) == 1)
143             xil_printf("Error performing PHY reset \n\n");
144         return -1;
145     }
146
147     /*endif*/
148
149     init_platform();
150     Configure_leds_ctrl();
151     xil_printf("Hello redpitaya \n\n");
152
153     /*If LWIP_IPV4==0
154     /* If LWIP_DMRP==1
155     ipaddr.addr = 0;
156     ipaddr.netmask = 0;
157     netmask.addr = 0;
158
159     /*else
160     /* initialize IP addresses to be used */
161     /*IP_ADDR(ipaddr, 169, 254, 17, 45);
162     /*IP_ADDR(netmask, 255, 255, 255, 0);
163     /*IP_ADDR(gw, 169, 254, 255, 255);
164
165     /*endif*/
166     print_app_header();
167
168     /*endif*/
169
170     /*make --no-print-directory pre-build
171     /*make --no-print-directory main-build
172     /*make[1]: Nothing to be done for "main-build".
173
174 16:00:18 Build Finished (took 53ms)

```

Console Vitis Log Guidance Problems  
Build Console (redpitaya\_ANF2023\_Debug)  
16:00:17 \*\*\*\* Incremental Build of configuration Debug for project redpitaya\_ANF2023 \*\*\*\*  
make  
make  
make --no-print-directory pre-build  
make --no-print-directory main-build  
make[1]: Nothing to be done for "main-build".  
16:00:18 Build Finished (took 53ms)

Pour retrouver l'adresse IP et MAC de la Red Pitaya il faut la carte SD insérer et le système d'exploitation Red Pitaya préchargé :

<https://redpitaya.readthedocs.io/en/latest/quickStart/SDcard/SDcard.html>



Procédure pour une connexion Ethernet directe :

Windows (le service Bonjour doit être installé pour Win 7/8)

1. Connectez le câble Ethernet et attendez env. 30 secondes
2. Ouvrez le navigateur Web et tapez **rp-xxxxxx.local/** dans le champ URL

Linux/Ubuntu

1. Ouvrez les paramètres réseau, modifiez la connexion et, pour le réseau LAN, sélectionnez Méthode **Partager avec d'autres ordinateurs** sous Paramètres IPv4.
2. Connectez le câble Ethernet et attendez env. 30 secondes
3. Ouvrez le navigateur Web et tapez **rp-xxxxxx.local/** dans le champ URL



Adresse IP dans System

Une dernière chose est nécessaire pour la communication Ethernet avec la redpitaya et notre programmation Bare Metal, c'est de modifier le fichier `xemacpsif_physpeed.c` dans le BSP de la platform project **Redpitaya\_ANF**.

Chemin d'accès du fichier xemacpsif\_physpeed.c :

C:\Xilinx\TP\_VIVADO\_2022\_2\Projets\_VITIS\_2022\redpitaya\_ANF\ps7\_cortexa9\_0\standalone\_domain\bsp\ps7\_cortexa9\_0\libsrv\lwip211\_v1\_8\src\contrib\ports\xilinx\netif\xemacpsif\_physpeed.c

Le contrôleur HARDWARE PHY LANTIQ sur la Redpitaya n'est pas inclus dans la librairie **lwip211\_v1\_8.... Gasp ! :(**

Ouvrir le fichier **xemacpsif\_physpeed.c** dans Vitis comme ci-dessous :



Récupérer le fichier xemacpsif\_physpeed.c sur  
[https://github.com/fabzz60/demo\\_adc\\_dac\\_Redpitaya\\_125\\_14](https://github.com/fabzz60/demo_adc_dac_Redpitaya_125_14)

Effacer l'ancien contenu et copier- coller entièrement le nouveau dans le fichier ouvert sur VITIS ci-dessus.

Sauvegarder: Ctrl +SHIFT + S puis clic droit sur redpitaya\_ANF-> Build Project

```

100 * (MAC or Beac). This MAC bus has multiple MAC available for both the
101 * MACs. The MACs share the same PHY bus. In this case, the bus can only be seen
102 * not be seen for the other MAC and hence the speed/SCLK settings of the other
103 * MAC cannot be programmed. Hence this kind of design will not work for
104 * this implementation.
105 */
106 #include "xemacpsif_physpeed.h"
107
108 #include "xemacpsif.h"
109 #include "xemacpsif_regs.h"
110 #include "xemacpsif_tx.h"
111 #include "xemacpsif_rx.h"
112 #include "xemacpsif_hw.h"
113 #include "xemacpsif.h"
114 #include "xemacpsif_mdmic.h"
115 #include "xemacpsif_physpeed.c"
116 #include "xemacpsif.h"
117
118 #endif
119
120 #define PHY_DETECT_REGS 1
121 #define PHY_IDENTIFIER_1_REGS 2
122 #define PHY_DETECT_REG 0x0100
123 #define PHY_IDENTIFIER_1_REG 0x0143
124 #define PHY_DETECT_MASK 0x0000
125 #define PHY_IDENTIFIER_1_IDENTIFIER
126 #define PHY_REALIDK_IDENTIFIER
127 #define PHY_LANTIQ_IDENTIFIER
128 #define IEEE_MII_CONTROL_REG
129 #define IEEE_MII_STATUS_REG
130 #define IEEE_MAC_STAT_REG 0x10
131 #define PHY_XILINX_PCS_PMA_ID1 0x0174
132 #define PHY_XILINX_PCS_PMA_ID2 0x0175
133 #define XEMACPS_GHII2RQHII_SPEED000_FD 0x0148
134 #define XEMACPS_GHII2RQHII_SPEED000_TO 0x0149
135 #define XEMACPS_GHII2RQHII_SPEED010_FD 0x0198
136 #define XEMACPS_GHII2RQHII_SPEED010_TO 0x0199
137 #define XEMACPS_GHII2RQHII_REG_NBR 0x10
138
139 #define PHY_REGCR 0x00
140 #define PHY_ADDR 0x0E
141 #define PHY_RGMIBCTL 0x3B
142 #define PHY_RGMIBCTL 0x32

```

The screenshot shows the Vitis IDE interface with the code editor open. A red box highlights the line of code containing `PHY_LANTIQ_IDENTIFIER_1_REG` at address `0x0565`. The code is part of the `xemacpsif_physpeed.c` file, which includes various PHY-related defines and register addresses.

Dans menu Explorer de Vitis-> Clic droit sur **redpitaya\_ANF2023 [standalone on ps7\_cortexa9\_0]**

Run As-> Launch Hardware ( single application debug)



Launch Hardware...



On va sauvegarder le projet complet sur une carte SD en faisant une image du projet : Dans le menu principal-> Xilinx-> Create Boot Image-> Zynq



## C:/Xilinx/TP\_VIVADO\_2022\_2/Projets\_VITIS\_2022/redpitaya\_ANF2023\_system/\_ide/bootimage/redpitaya\_ANF2023\_system.bif



## Dans Create Boot Image-> Create Image



Bootimage generated successfully!

Fichier Boot dans:

C:\Xilinx\TP\_VIVADO\_2022\_2\Projets\_VITIS\_2022\redpitaya\_ANF2023\_system\\_ide\bootimage\BOOT.bin

Copier-coller le fichier **BOOT.bin** sur une micro-SD via un adaptateur SD to micro-SD et l'insérer dans l'emplacement micro-SD de la Redpitaya.

Redémarrer la Redpitaya et tester le programme.

Fin de la Démo ADC/DAC avec Echo Ethernet !

# Script Python Echo ethernet

The screenshot shows the Thonny IDE interface. The top menu bar includes Fichier, Édition, Affichage, Exécuter, Outils, and Aide. The main window has tabs for 'led\_blink\_echo\_client\_for\_Red\_Pitaya\_125\_14.py' and 'Assistant'. The code editor contains the following Python script:

```
4 import time
5 #import sys
6
7 HOST = "169.254.17.45" # Standard loopback interface address (localhost)
8 PORT = 7 # Port to listen on (non-privileged ports are > 1023)
9
10 print('Create a socket on the host PC client.')
11 lwIP_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
12
13 print('Connect to the socket of the lwIP server listening on the redpitaya')
14 lwIP_server_address = (HOST, PORT)
15 lwIP_socket.connect(lwIP_server_address)
16
17 def echo_packet(lwIP_socket, message):
18     message_byte = message.encode()
19
20     lwIP_socket.sendall(message_byte)
21
22     bytes_buffer_size = 32
23     bytes_received = 0
24     bytes_total = len(message)
25
26     while bytes_received < bytes_total:
27         message_recv = lwIP_socket.recv(bytes_buffer_size)
28         bytes_received += len(message_recv)
29     print(message_recv)
30
```

The 'Console' tab shows the output of the script, which is sending and receiving messages to control three LEDs (LED0, LED1, LED2, LED3) on a Red Pitaya board. The 'Assistant' tab provides help for the plotter feature.

```
#-* coding : utf-8-*-

import tkinter      # import de tkinter

import socket

import time

#import sys

HOST = "169.254.17.45" # Standard loopback interface address (localhost)

PORT = 7 # Port to listen on (non-privileged ports are > 1023)

print('Create a socket on the host PC client.')

lwIP_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

print('Connect to the socket of the lwIP server listening on the redpitaya')

lwIP_server_address = (HOST, PORT)

lwIP_socket.connect(lwIP_server_address)

def echo_packet(lwIP_socket, message):

    message_byte = message.encode()

    lwIP_socket.sendall(message_byte)
```

```

bytes_buffer_size = 32
bytes_received = 0
bytes_total = len(message)
while bytes_received < bytes_total:
    message_recv = lwIP_socket.recv(bytes_buffer_size)
    bytes_received += len(message_recv)
    print(message_recv)

try:
    while True:
        message = 'LED0 on'
        echo_packet(lwIP_socket, message)
        time.sleep(0.5)
        message = 'LED1 on'
        echo_packet(lwIP_socket, message)
        time.sleep(0.5)
        message = 'LED2 on'
        echo_packet(lwIP_socket, message)
        time.sleep(0.5)
        message = 'LED3 on'
        echo_packet(lwIP_socket, message)
        time.sleep(0.5)
        message = 'LED0 off'
        echo_packet(lwIP_socket, message)
        time.sleep(0.5)
        message = 'LED1 off'
        echo_packet(lwIP_socket, message)
        time.sleep(0.5)
        message = 'LED2 off'
        echo_packet(lwIP_socket, message)
        time.sleep(1)
        message = 'LED3 off'
        echo_packet(lwIP_socket, message)

```

```

time.sleep(1)

message = 'All LEDs on'

echo_packet(lwIP_socket, message)

time.sleep(1)

message = 'All LEDs off'

echo_packet(lwIP_socket, message)

time.sleep(1)

finally:

    print('Closing the socket from the host PC client side...')

    lwIP_socket.close()

```

Ouvrir Putty et le port USB-série (COMx) correspondant à la carte Redpitaya détecté et visualiser les infos ci-dessous.



```

COM4 - PuTTY

Gateway : 169.254.255.255
TCP echo server started @ port 7
hello redpitaya

-----lwIP TCP echo server -----
TCP packets sent to port 6001 will be echoed back
JMT dit: Physical device found !! (31049 @ 1)
Found LANTIQ: Starting Auto negociation...
Attente du Reset...
Reset DONE
Lantiq Mdio.MiiCtrl B300x Rst Skews Rx=l500 Tx=l500 (ps)
phy1 Waiting for PHY to complete autonegotiation
Return 1000
link speed for phy address 1: 1000
unable to determine type of EMAC with baseaddress 0xE000B000
Board IP: 169.254.17.45
Netmask : 255.255.255.0
Gateway : 169.254.255.255
TCP echo server started @ port 7
command = LED0 on
LED0 on
command = LED1 on
LED1 on
command = LED2 on
LED2 on
command = LED0 on
LED0 on
command = LED1 on
LED1 on
command = LED2 on
LED2 on

```

## Test Bench module VHDL frequency\_modulation@125KHz:



Calcul des points sur Excel :



## Calcul des points sous Matlab :

