1.McASP
McASP是美国TI公司的DSP的一种接入接口。称为复通道音频接入接口。这是一种通用的音频接入接口。采用的是时分复用的数据流形式。
https://wenku.baidu.com/view/ccc1e9fdba0d4a7302763a3d.html。
McASP即multi-channel audio serial port,是通用音频接口,支持TDM(Time-Division Multiplexed stream)协议、I2S协议等。McASP可以非常灵活的与S/PDIF (Sony/Philips Digital Interface)等接口连接。McASP的数据线可以灵活的配置成输入或者输出,同步模式则根据具体接口设计来决定,可以配置成主模式(由内部生成帧同步、字同步、位同步)或者从模式(由外部提供帧同步、字同步、位同步)。
从字面上理解,多通道音频串行接口,我们可以知道两点:多个通道和串行。
McASP接口的时钟(包括帧同步、字同步、位同步)是独立的,这也就意味着McASP可以设置输入输出不同采样率的数据。
1.1McASP的硬件架构
先看结构框图,从下面可以知道其大概分为五部分:
1) FIFO:很有用的东西,通信接口一般都用的着,缓解CPU高速和端口慢速的矛盾。
2) 发送/接受格式单元:说明了就是把数据转换成人家特定的格式发送,通过它可以设定MSB/LSB,那些位没有用,可以MARK掉,还有rotate(是个什么鬼,没有搞懂,也没有用到)。
3) 状态机:这么复杂的设备,有了状态机,使进程控制更加简单,当然这也都是CPU自己完成的,用户不用关心,只需要初始化时把它打开就行。顺便提一句,Good Program Practice 可以多用状态机写。
4) Serializer:也就是串行器了,CPU内部数据传输都是并行,需要靠他完成并/串,串/并转换。
5) Clock Generator:时钟产生器,这个相当重要,