1a4eb2001SXianjun Jiao<!-- 2a4eb2001SXianjun JiaoAuthor: Xianjun jiao 3a4eb2001SXianjun JiaoSPDX-FileCopyrightText: 2019 UGent 4a4eb2001SXianjun JiaoSPDX-License-Identifier: AGPL-3.0-or-later 5a4eb2001SXianjun Jiao--> 6a4eb2001SXianjun Jiao 756ab2d85SJiao XianjunOne super power of the openwifi platform is "**Full Duplex**" which means that openwifi baseband can receive its own TX signal. Just like a radar! This brings a unique capability of "**joint radar and communication**" to openwifi. For instance, put two directional antennas to openwifi TX and RX, and the **CSI** (Channel State Information) of the self-TX signal will refect the change of the target object. 8a4eb2001SXianjun Jiao  9a4eb2001SXianjun Jiao 10a4eb2001SXianjun Jiao## Quick start 11a4eb2001SXianjun Jiao- Power on the SDR board. 12a4eb2001SXianjun Jiao- Connect a computer to the SDR board via Ethernet cable. The computer should have static IP 192.168.10.1. Open a terminal on the computer, and then in the terminal: 13a4eb2001SXianjun Jiao ``` 14a4eb2001SXianjun Jiao ssh [email protected] 15a4eb2001SXianjun Jiao (password: openwifi) 16*3712d8b7SXianjun Jiao ``` 17*3712d8b7SXianjun Jiao- On computer, build the latest driver and FPGA package after clone/update openwifi and openwifi-hw-img repository: 18*3712d8b7SXianjun Jiao ``` 19*3712d8b7SXianjun Jiao export XILINX_DIR=your_Xilinx_install_directory 20*3712d8b7SXianjun Jiao (Example: export XILINX_DIR=/opt/Xilinx. The Xilinx directory should include sth like: Downloads, Vitis, etc.) 21*3712d8b7SXianjun Jiao export OPENWIFI_HW_IMG_DIR=your_openwifi-hw-img_directory 22*3712d8b7SXianjun Jiao (The directory where you get the open-sdr/openwifi-hw-img repo via git clone) 23*3712d8b7SXianjun Jiao export BOARD_NAME=your_board_name 24*3712d8b7SXianjun Jiao (Check the BOARD_NAME definitions in README) 25*3712d8b7SXianjun Jiao 26*3712d8b7SXianjun Jiao cd openwifi/user_space 27*3712d8b7SXianjun Jiao ./drv_and_fpga_package_gen.sh $OPENWIFI_HW_IMG_DIR $XILINX_DIR $BOARD_NAME 28*3712d8b7SXianjun Jiao scp drv_and_fpga.tar.gz [email protected]:openwifi/ 29*3712d8b7SXianjun Jiao scp ./side_ch_ctl_src/side_ch_ctl.c [email protected]:openwifi/ 30*3712d8b7SXianjun Jiao scp ./inject_80211/* [email protected]:openwifi/inject_80211/ 31*3712d8b7SXianjun Jiao ``` 32*3712d8b7SXianjun Jiao- On SDR board (/root/openwifi directory): 33*3712d8b7SXianjun Jiao ``` 34*3712d8b7SXianjun Jiao cd /root/openwifi/ 35*3712d8b7SXianjun Jiao ./wgd.sh drv_and_fpga.tar.gz 36*3712d8b7SXianjun Jiao ./monitor_ch.sh sdr0 1 37*3712d8b7SXianjun Jiao insmod ./drv_and_fpga/side_ch.ko 38*3712d8b7SXianjun Jiao gcc -o side_ch_ctl side_ch_ctl.c 39a4eb2001SXianjun Jiao ./side_ch_ctl wh1h4001 40a4eb2001SXianjun Jiao ./side_ch_ctl wh7h4433225a 41*3712d8b7SXianjun Jiao (Above two commands ensure receiving CSI only from XX:XX:44:33:22:5a, which will be set by our own packet injector later) 42a4eb2001SXianjun Jiao ./sdrctl dev sdr0 set reg xpu 1 1 43a4eb2001SXianjun Jiao (Above unmute the baseband self-receiving to receive openwifi own TX signal/packet) 44a4eb2001SXianjun Jiao ./side_ch_ctl g0 45a4eb2001SXianjun Jiao ``` 46*3712d8b7SXianjun Jiao- Open another ssh session on SDR board: 47a4eb2001SXianjun Jiao ``` 48*3712d8b7SXianjun Jiao cd /root/openwifi/inject_80211 49*3712d8b7SXianjun Jiao make 50*3712d8b7SXianjun Jiao ./inject_80211 -m g -r 4 -t d -e 0 -b 5a -n 99999999 -s 20 -d 1000 sdr0 51a4eb2001SXianjun Jiao 52*3712d8b7SXianjun Jiao (Above command injects the 802.11a/g packet, for 802.11n packet please use: 53*3712d8b7SXianjun Jiao ./inject_80211 -m n -r 4 -t d -e 8 -b 5a -n 99999999 -s 20 -d 1000 sdr0) 54*3712d8b7SXianjun Jiao ``` 55*3712d8b7SXianjun Jiao- Now you should see the increasing numbers in the previous ssh terminal of the SDR board. 56*3712d8b7SXianjun Jiao- On your computer (NOT ssh session!), run: 57a4eb2001SXianjun Jiao ``` 58a4eb2001SXianjun Jiao cd openwifi/user_space/side_ch_ctl_src 59*3712d8b7SXianjun Jiao python3 side_info_display.py 8 waterfall 60a4eb2001SXianjun Jiao ``` 61*3712d8b7SXianjun Jiao The python script needs "matplotlib.pyplot" and "numpy" packages installed. Now you should see figures showing run-time **CSI**, **CSI waterfall**, **Equalizer out** and **frequency offset**. The following photo shows the CSI change in the waterfall plot when I left my seat in front of two directional antennas (Tx/Rx antenna). 6290a96182SXianjun Jiao  6390a96182SXianjun Jiao 64*3712d8b7SXianjun Jiao While running, all CSI data is also stored into a file **side_info.txt**. A matlab script **test_side_info_file_display.m** is offered to help you do CSI analysis offline. In this case, run **test_side_info_file_display** in Matlab. 65*3712d8b7SXianjun Jiao  66*3712d8b7SXianjun Jiao 67a4eb2001SXianjun JiaoPlease learn the python and Matlab script for CSI data structure per packet according to your requirement. 68a4eb2001SXianjun Jiao 69a4eb2001SXianjun JiaoDo read the [normal CSI app note](csi.md) to understand the basic implementation architecture. 70