基于GNU Radio和HackRF/LimeSDR的802.11收发机

本文内容、开发板及配件仅限用于学校或科研院所开展科研实验!

温馨提示:“开源SDR实验室”是北京的。

目录

一、实验硬件软件

二、编译安装

1、gr-foo安装

2、gr-ieee802-11安装

3、调整最大共享内存

4、编译和运行wifi_phy_hier.grc

5、可能碰到的问题及解决方法

三、测试例子

1、wifi_loopback.grc

2、wifi_rx.grc

四、有用的链接


 

本文介绍的内容来自SRIF 2013中的一篇论文:An IEEE 802.11a/g/p OFDM Receiver for GNU Radio。正如题目所示,本论文实现了一个符合802.11a/g/p规范的接收机,当然作者也做了发射机。

SRIF '13: Proceedings of the second workshop on Software radio implementation forum 2013

http://conferences.sigcomm.org/sigcomm/2013/srif.php

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第1张图片

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第2张图片

802.11大家都非常熟悉了,具体内容可以参见:

http://www.ieee802.org/11/

https://baike.baidu.com/item/IEEE%20802.11/8447947?fromtitle=802.11&fromid=6262490&fr=aladdin

一、实验硬件软件

硬件---HackRF One或者LimeSDR都可以,拉杆天线或者专门的2.4G/5G/5.8G天线,具体信息参见:

https://item.taobao.com/item.htm?spm=a230r.1.14.231.380979baTZfPmA&id=526187854860&ns=1&abbucket=20#detail

https://item.taobao.com/item.htm?spm=a230r.1.14.27.22b977ffORpxg7&id=555064600966&ns=1&abbucket=8#detail

https://item.taobao.com/item.htm?spm=2013.1.w4004-13255721713.14.9827635dxVAVbP&id=535820594576

软件---Ubuntu运行支持HackRF、Limesdr的环境,gr-foo和gr-ieee802-11模块。

二、编译安装

1、gr-foo安装

如果你用git clone下载最新的gr-foo,可能会由于你电脑中的cmake版本低,导致出现cmake编译不通过的问题。

(1)更新cmake

我之前的cmake是apt-get install的,版本是3.5.1,版本有点老了,然而gr-foo需要至少是3.8的版本。

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第3张图片

参照https://cmake.org/install/,更新方法如下:

从https://cmake.org/download/下载你需要的cmake源码,这里我下载的是3.17版本的。

./bootstrap
make
sudo make install

注意:当你执行./bootstrap的时候,可能会碰到提示信息,例如OpenSSL之类的。你就根据提示信息,关闭openssl的选项就行了。具体操作例如

./bootstrap -- -DCMAKE_USE_OPENSSL=OFF

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第4张图片

执行完./bootstrap -- -DCMAKE_USE_OPENSSL=OFF之后,

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第5张图片

执行完make之后

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第6张图片

执行完sudo make install之后,

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第7张图片

更新完cmake之后,你再执行cmake --version,就会发现,你的cmake版本已经更新完成了。

(2)gr-foo安装

因为gr-foo针对gnuradio的不同版本(如gnuradio3.7,gnuradio3.8)实现了相应的版本。由于我Ubuntu中的gnuradio版本是3.7的,如果用最新版本的gr-foo,会提示如下信息。

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第8张图片

关于如何下载github上指定版本代码的方法,请参见:https://blog.csdn.net/cc13949459188/article/details/88567736

这里我们使用第一种方法,到gr-foo的github主页https://github.com/bastibl/gr-foo,在Branch这里,我们选择3.7的版本,然后点击“Clone or download”进行下载,下载解压后的文件夹名字是gr-foo-maint-3.7

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第9张图片

依次执行以下编译安装命令:

cd gr-foo-maint-3.7
mkdir build
cd build
cmake ..
make
sudo make install
sudo ldconfig

 

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第10张图片

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第11张图片

【注意】:这里的foo他默认安装到了/usr/lical/lib/python2.7/dist-packages/foo文件夹中,后边会提到,这可能会导致GRC Python找不到这个foo,导致出现ImportError信息。解决办法请看本文后边。

正确安装完之后,你的GRC中会出现这个foo模块。

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第12张图片

2、gr-ieee802-11安装

在编译安装gr-ieee802-11的时候,同样需要注意选择3.7版本的。否则,如果直接git最新的3.8版本,如果你电脑的gnuradio版本是3.7的话,也会出现以下的信息。

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第13张图片

同样,到gr-ieee802-11的github主页https://github.com/bastibl/gr-ieee802-11,在Branch这里,我们选择3.7的版本,然后点击“Clone or download”进行下载,

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第14张图片

依次执行以下编译安装命令:

cd gr-ieee802-11-maint-3.7
mkdir build
cd build
cmake ..
make
sudo make install
sudo ldconfig

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第15张图片

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第16张图片

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第17张图片

3、调整最大共享内存

由于transmitter使用Tagged Stream模块,因此它在处理之前必须将完整的frame存储在缓冲区中。由于ubuntu默认的缓冲区空间太小,应用如下命令进行设置:

sudo sysctl -w kernel.shmmax=2147483648

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第18张图片

4、编译和运行wifi_phy_hier.grc

这是运行本项目其他grc文件的前置步骤。但是,我在第二个电脑上重新按照本博客的方法来安装后,没有碰到这个问题,所以,暂时先留在这里吧。

【注意】如果不先运行本程序,其它grc(例如gr-ieee802-11-maint-3.7/examples/wifi_rx.grc)会出现missing block。

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第19张图片

OFDM PHY:物理层被封装在一个分层块中,以便在GNU Radio Companion中获得更清晰的收发器结构。

用GNU Radio Companion打开/examples/wifi_phy_hier.grc 点击build进行创建,该模块将会安装加载到GRC中。

5、可能碰到的问题及解决方法

我在第二个电脑上重新按照本博客的方法来安装后,没有碰到以下两个问题,所以,暂时先留在这里吧,大家根据自己的实际情况来看,如果你安装完了gr-ieee802-11之后,运行不会碰到以下两个问题,那么就可以暂时忽略不用看这部分。

(1)import foo ImportError No module named foo

这是由于我按照上述cmake make make install的时候,把foo安装到了/usr/local/lib/python2.7/dist-packages/foo中,导致这时候Python找不到foo,因为Python默认的是从/usr/lib中来寻找的。所以,通过将/usr/local/lib/python2.7/dist-packages/foo复制到/usr/lib来解决。

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第20张图片

解决方法:

sudo cp -r  /usr/local/lib/python2.7/dist-packages/foo /usr/lib

(2)ImportError:libgnuradio-foo.so: cannot open shared object file: No such file or directory

根据提示信息,定位到是可能找不到libgnuradio-foo.so,从电脑这种查找要一下这个libgnuradio-foo.so的位置,得知它是在/usr/local/lib/文件夹中,把它复制到/usr/lib文件夹中。

解决方法:

sudo cp /usr/local/lib/libgnuradio-foo.so /usr/lib

(3)Xterm executable is missing

暂时可以忽略不管他。

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第21张图片

三、测试例子

1、wifi_loopback.grc

在已打开的GRC(在打开的终端中,输入gnuradio-companion来打开GRC,)中运行wifi_loopback.grc,依次点击build和运行按钮后,你会看到类似的结果。

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第22张图片

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第23张图片

2、wifi_rx.grc

打开wifi_rx.grc,该文件的作者用的是USRP,这里由于我们使用的是HackRF或者LimeSDR,所以需要将UHD Source修改为osmocom source或者LimeSuite Source(Rx)模块。

我这个最近新安装的ubuntu电脑,用hackrf的时候,碰到一个小插曲问题,就是osmocom source模块中的device如果默认什么都不填写的话,会碰到如下问题:

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第24张图片

解决方法:在osmocom source模块的Device Arguments栏中,输入:hackrf=0,这是根据osmocom source模块的documentation选项卡中提示的来确定的。【也请大家各自验证一下是否会存在此问题。我记得之前我用osmocom source模块是不会碰到此类问题的。】

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第25张图片

我的手机热点名字是:HUAWEI nova 2s,其MAC地址是b8:94:36:cf:3b:90,以下是我手机的截图和捕获到的数据包的截图。

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第26张图片

可以看到捕获到的数据包中,热点的SSID名称和MAC地址与我手机的信息是一致的。

基于GNU Radio和HackRF/LimeSDR的802.11收发机_第27张图片

四、有用的链接

http://conferences.sigcomm.org/sigcomm/2013/srif.php

https://cmake.org/install/

https://github.com/bastibl/gr-ieee802-11

使用过程中,如果碰到什么问题,欢迎联系反馈!

https://item.taobao.com/item.htm?spm=a230r.1.14.231.380979baTZfPmA&id=526187854860&ns=1&abbucket=20#detail

 

 

 

 

 

 

 

你可能感兴趣的:(HackRF,LimeSDR)