dsp McBSP模块「建议收藏」

dsp McBSP模块「建议收藏」McBSP,是多通道缓冲串行接口。在DSP嵌入式系统中,常常用来连接音频编码解码芯片,串行AD/DA器件等。具有如下特性:全双工;两个数据缓冲寄存器;独立的发送和接收帧和时钟;多达129通道的发送和接收等等。McBSP结构图如下:首先对引脚进行介绍:CLKR:接收时钟CLKX:发送时钟CLKS:外部时钟源DR“:串行数据接收DX:串行数据发送

大家好,又见面了,我是你们的朋友全栈君。

McBSP,是多通道缓冲串行接口。在DSP嵌入式系统中,常常用来连接音频编码解码芯片,串行AD/DA器件等。具有如下特性:

全双工;

两个数据缓冲寄存器;

独立的发送和接收帧和时钟;

多达129通道的发送和接收等等。

McBSP结构图如下:

dsp McBSP模块「建议收藏」

首先对引脚进行介绍:

CLKR:接收时钟

CLKX:发送时钟

CLKS:外部时钟源

DR“:串行数据接收

DX:串行数据发送

FSR:接收同步帧

FSX:发送同步帧

注意到接收部分是三重缓冲,发送部分是两重缓冲。


接下来介绍它的相关寄存器:

DRR:数据接收寄存器,存放接收到的数据。

DXR:数据发送寄存器,存放将要发送的数据。

SPCR:串行接口控制寄存器,配置串行接口,包括状态控制字位,可得知工作状态,分为SPCR1和SPCR2,分别是收和发。

RCR:接收控制寄存器,设置接收操作的参数。

XCR:发送控制寄存器,设置发送操作的参数。

SRGR:设置波特率相关。

MCR:多通道控制寄存器,设置多通道选择模式。也是分收、发两个。

RCER:接收通道使能寄存器,分A/B区,使能奇偶组的16个通道可选。

XCER:发送通道使能寄存器,同上。

PCR:引脚控制寄存器,配置串口作用,和SPCR配合。


这里有必要弄懂什么是多通道?当初是纠结了很久。

这个多通道不是AD采样器那个多通道,而是类似于时分复用的数据流,强调时隙的概念。128个发送通道和128个接收通道,一帧数据最多128个通道,也即128个数据单元,一个通道可以移近或移出一个串行字。那么这一帧里面还分八个子帧,每个子帧16个通道,这样总共就是128个通道。这八个子帧还分两区,偶数为A区,奇数为B区。通过使能寄存器确定每个区16个通道哪些要使用。


关于编程架构:

1、首先创建结构体,配置:

MCBSP_Config myMCBSP = {

MCBSP_SPCR1_RMK(

),

MCBSP_SPCR2_RMK(

),

}

2、创建句柄并配置:

hMcbsp = MCBSP_open(MCBSP_PORT1,MCBSP_OPEN_RESET);

MCBSP_config(hMcbsp,&myMCBSP);

delay(); //注意寄存器配置完成后需要延时,以便内同步

注意它和EDMA一样,配置需要句柄。

3、各种使能:

MCBSP_enableSrgr(hMcbsp);

delay(); //内同步

MCBSP_enableRcv(hMcbsp);

MCBSP_enableXmt(hMcbsp);

..

有些资料是用另外一个函数搞定:

MCBSP_start(hMcbsp,MCBSP_RCV_START | MCBSP_XMIT_START,0);

4、收发的实现

MCBSP_read16(hMcbsp);

MCBSP_write16(hMcbsp,buff);

里面具体的代码就是对DRR或者DXR进行赋值和返回。

实际的收发有两种实现方法,一种是查询SPCR状态位,一种是中断,中断实时性高,建议使用。有对应的中断ID。

rcvEventID = MCBSP_getRcvEventId(hMcbsp);

再来个plug函数就能绑定中断程序。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/143589.html原文链接:https://javaforall.net

(0)
上一篇 2022年5月21日 上午10:20
下一篇 2022年5月21日 上午10:40


相关推荐

  • centos7安装Pycharm_pycharm安装库

    centos7安装Pycharm_pycharm安装库DownloadPyCharm:PythonIDEforProfessionalDevelopersbyJetBrainshttps://www.jetbrains.com/pycharm/download/#section=linux官网下载pycharm的linux版下载后解压tar-xzvfpycharm-professional-2021.1.3.tar.gz-C/tmpcd/tmp/pycharm-2021.1.3/bin/运行pycharm.

    2022年8月27日
    7
  • 【Python+OpenCV】二值化函数cv2.threshold()的用法详解

    【Python+OpenCV】二值化函数cv2.threshold()的用法详解文章目录函数原型参数说明传入参数 返回值 用法举例总结函数原型 Python cv2 threshold src thresh maxval type dst retval dst 参数说明传入参数 src 输入图片 thresh 阈值 取值范围 0 255maxval 填充色 取值范围 0 255type 二值化使用什么类型的算法 常见 type 为 0 cv2 THRESH BINARY 其中 type 的值有如下对应关系 阈值小于阈值的像素点大于阈值

    2026年3月18日
    2
  • node rimraf模块 递归删除文件夹内容

    node rimraf模块 递归删除文件夹内容使用 webpackbuild 文件项目时每次都会生成一个 dist 目录 有时需要把 dist 目录里的所以旧文件全部删掉 除了可以使用 rm rf dist 命令删除外 还可以使用 rimraf dist 命令 rimraf 的作用 以包的形式包装 rm rf 命令 用来删除文件和文件夹的 不管文件夹是否为空 都可删除局部安装 npminstallri dev 全局安装 npminstallri g 使用 rimraf path path

    2026年3月18日
    1
  • java mongodb 使用MongoCollection,BasicDBObject 条件查询

    java mongodb 使用MongoCollection,BasicDBObject 条件查询

    2021年6月7日
    185
  • API函数详解

    API函数详解API 函数详解 nbsp 首先 有必要向大家讲一讲 什么是 API 所谓 API 本来是为 C 和 C 程序员写的 API 说来说去 就是一种函数 他们包含在一个附加名为 DLL 的动态连接库文件中 用标准的定义来讲 API 就是 Windows 的 32 位应用程序编程接口 是一系列很复杂的函数 消息和结构 它使编程人员可以用不同类型的编程语言编制出的运行在 Windows95 和 Windows nbsp NT 操作系统上的应用程序 可以说

    2026年3月19日
    2
  • Python继承_qpython

    Python继承_qpython 2017年1月2日,星期一python_继承 null

    2022年10月10日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号