USRP2 LTE Transceiver设计

本文详细介绍了USRP2 LTE Transceiver的代码架构,包括关键数据结构和数据流。主要讨论了接收和发送数据的线程工作流程,以及FIFO在多线程同步中的作用。此外,还提及了变速率采样处理和在多处理器系统中的性能优化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 代码架构

top_level

runTransceiver.cpp初始化设备对象,radio接口以及transceiver对象,启动trx相关线程

 

transceiver

Transceiver.h/cpp

TRX层,主要实现收发控制功能和对上层协议栈的接口,共分为四个线程:

mReceiveFIFOServiceLoopThread负责驱动USRP接收,并将数据存入RxFIFO中;mTransmitFIFOServiceLoopThread负责从TxFIFO中获取数据,并驱动USRP发送;mTransmitDataQueueServiceLoopThread负责与上层协议栈的连接,准备发送数据,并存入TxFIFO;

mReceiveDataQueueProcessLoopThread负责从RxFIFO中取出接收数据,并交给上层协议栈处理。

 

radioInterface.h/cpp

无线设备接口,用于驱动设备进行基本的收发,并返回接收buffer

driveTransmitRadio() 将tx databuf存入radiointerface的sendbuf中,并驱动usrp writesamples();

driveReceiveRadio() 驱动usrp readsamples()并将数据存如RxFIFO中,实际上,radiointerface的fifo和tranceiver的fifo是一个fifo,在runTranceiver中通过引用联系在一起。

 

arch

radioDevice.h/cpp 抽象的设备类,提供设备收发,控制等接口

UHDDevice.h/cpp 实现USRP2的各种操作,初始化,收发数据,打印异步信息等

 

common

Parameters.h 提供系统参数,如采样率,一个subframe的采样点数等宏定义

Common目录下提供了常用的数据类封装,如Thread类/FIFO类/Log类等

2. 关键数据结构 

定点数据的FIFO

class FixPointVectorFIFO : public InterthreadQueueWithWait<short> {};

InterthreadQueueWithWait是线程间同步使用的,支持阻塞读写和等待功能的队列,其底层是链表实现的。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值