1.目的
HDMI RX接收到音频数据包(Audio packet),FPGA将得到的音频数据包解析并通过I2S协议发送给DAC芯片(CS4344),DAC芯片驱动后端功放以带动喇叭发出正确声音。
2.音频基础知识
2.1音频编码格式
2.1.1L-PCM
PCM技术,采用最简单的二进制编码,将量化的数据以二进制码流的形式进行存储,没有进行加密编码。L-PCM是更高采样精度和深度的PCM技术。
2.1.2 IEC60958
https://www.cnblogs.com/fellow1988/p/6445489.html
IEC 60958是一种传递数字音频的接口规范,通过一根线同时传递时钟信号和数据信号。IEC 60958可用来传递两channel,16/20/24bits采样深度的PCM数据。
2.1.2.1 BMC编码(SPDIF)
IEC 60958在传输数据时使用双相符号编码(Biphase Mark Code),简称BMC,属于一种相位调制(phase modulation)的编码方法,是将时钟讯号和数据讯号混合在一起传输的编码方法。下图是BMC的示意图
在BMC编码中,时钟信号的频率是数据传输比特率的两倍。BMC信号在时钟信号的上升沿跳变。在时钟下降沿,BMC是否跳边取决于数据信号,当数据信号是高电平时,BMC跳变。当数据信号是低电平时,BMC不跳变。在音频信号在硬件间传递时,是传递的BMC信号,接收端对BMC解码,解析出时钟信号与数据信号。
2.1.2.2协议格式
由192个帧(Frame)构成的块(Block),而每个Frame储存了两个声道(channel)的一组采样信号(Sample),分为Cha