IIS总线接口解析

接口/总线/驱动

1142人已加入

描述

现在,在市场上有很多不同形式的数字音频系统,例如磁带,数字音频带,数字声音处理器以及数字TV声音,而这些数字音频系统也得到了消费者的喜爱。而S3C2440A集成电路内部的声音总线接口可以用来做一个外部8/16位立体声编码解码器集成电路微型磁带或者便携式设备的编码解码器接口。同时IIS总线接口支持IIS总线数据模式和最高有效位对齐数据模式。而为先入先出(FIFO)通道提供DMA传输模式接口而不是中断接口。在DMA传输模式时,总线可以同时传输和接收也可以实现在一次传输中传递和接收分离

IIS框图:

总线接口

功能描述:

总线接口,寄存器存储以及状态机(BRFC):状态机控制总线接口逻辑和先入先出通道。

双5位预分频器(IPSR):一个预分频器用作IIS总线接口的主机时钟产生器,而另一个用作外部编码解码器时钟产生器。

64字节先入先出存储(TXFIFO和RXFIFO):在发送时,数据写入TXFIFO。而在接收时,数据从RXFIFO中读取。

主机IIS时钟产生器(SCLKG):在主机模式时,串行数据时钟由主机产生。

声道产生器和状态机(CHNC):IISCLK和IISLRCK是由声道状态机产生控制的。

16位位移寄存器(SFTR):在发送模式,并行数据转移到串行数据输出。在接收模式,串行数据转移到并行数据。

发送或接收模式

正常发送:

IIS控制寄存器为发送和接收FIFO设置了先入先出就绪标志位。当FIFO准备来发送数据时,如果FIFO为非空,那么FIFO就绪标志将会被设为1,而如果发送FIFO为空,FIFO就绪标志将被设为0。当接收FIFO为未满时,FIFO就绪标志位设为1,它表明FIFO准备来接收数据了。如果接收FIFO满了时,FIFO就绪标志位设为0 。这些标志位可以决定CPU何时读写FIFO。而当CPU用这种方式获得发送接收FIFO时,串行数据就可以发送或接收了。

DMA发送:

在这种模式时,使用DMA控制器发送或者接收FIFO。而在发送或者接收模式时,DMA服务请求有FIFO的就绪标志决定。

发送和接收模式:

在这种模式时,IIS总线接口可以同时发送和接收数据。

音频串行接口格式

IIS总线格式:

IIS总线有四条线,包括串行数据输入(IISDI),串行数据输出(IISDO),左/右声道选择(IISLRCK)以及串行位时钟(IISCLK)。主机产生IISLRCK和IISCLK。

串行数据以最高有效位在前的方式发送二的补码。而最高有效位先传输是因为发送方和接收方可能有不同的字符长度。发送方不必知道接收方可以处理多少位的数据,同样接收方也不需要知道有多少位要接收。

当系统的字符长度要比接收方的字符长度长时,发送的字符将被缩短(最低有效数据位将设为0)。如果接收方获得了多于他字符长度的位数时,这些多接收的位数在最低有效位后将被忽略。相反的,如果接收方获得少于他字符长度的数据时,那些空余的位将在内部设为0 。因此最高有效位有一个固定的位置,而最低有效位的位置将取决于字符长度。当IISLRCK信号改变时,发送方在一个时钟周期里发送下一字符的最高有效位。

发送方发送的串行数据即可以与时钟信号的下降沿同步,也可以与时钟信号的上升沿同步。然而串行数据必须发送到接收方在时钟信号的的上升沿,因此在上升沿发送数据有一些要求。

左/右声道选择线表明被传输的声道。IISLRCK即可以在时钟的下降沿又可以在时钟的上升沿改变。而他不需要对称,在从机中,这个信号在时钟信号的上升沿发出。IISLRCK线在最高有效字节位传输完的一个时钟周期后改变。这就允许从机发送方去发送串行数据在同步时间。此外,他使能接收方来存储以前的字符,同时为下一个字符清除输入。

最高有效位对齐(左对齐):

在总体框架上,最高有效位/左对齐有格式与IIS总线格式十分相似。而唯一与IIS总线格式不同的是最高有效位对齐格式总是在IISLRCK一改变后就发送下一字符的最高有效位。

IIS总线格式和最高有效位格式对比:

总线接口

采样频率与主机时钟:

主机时钟频率(PCLK或者MPLLin)可以被采样频率选择,如下表。

总线接口

由于主机时钟由IIS预分频决定。所以预分频值和主机时钟类型(256 或者384fs)应该合适的决定。而串行位时钟频率类型(16/32/48fs)可以由每个声道的串行位和主机时钟决定。如下表:

总线接口

IIS总线接口专属寄存器

IIS控制寄存器(IISCON)

总线接口

注:

1.IISCON寄存器的每一位都可以被访问,半字和字单元可以用STRB/STRH/STR和LDRB/LDRH/LDR指令,或者char/short int/int类型指针在小/大端模式。

2.(Li/HW/W) : 小/半字/字

(Bi/HW/W) : 大/半字/字

IIS模式寄存器(IISMOD)

总线接口

注:

1.IISMOD寄存器的每一位都可以被访问,半字和字单元可以用STRB/STRH/STR和LDRB/LDRH/LDR指令,或者char/short int/int类型指针在小/大端模式。

2.(Li/HW/W) : 小/半字/字

(Bi/HW/W) : 大/半字/字

IIS预分频寄存器(IISPSR)

总线接口

注:

1.IISFCON寄存器的每一位都可以被访问,半字和字单元可以用STRB/STRH/STR和LDRB/LDRH/LDR指令,或者char/short int/int类型指针在小/大端模式。

2.(Li/HW/W) : 小/半字/字

(Bi/HW/W) : 大/半字/字

IIS FIFO寄存器(IISFIFO)

总线接口

IIS总线接口包含两个64字节FIFO用在收发模式。每一个FIFO有16位宽和32位宽格式,这就允许FIFO处理半字单元数据而不用管有效值的大小。发送和接收FIFO通道通过FIFO入口编程。而这个入口是0x55000010。

总线接口

注:

1.IISFIFO寄存器的每一位都可以被访问,半字和字单元可以用STRB/STRH/STR和LDRB/LDRH/LDR指令,或者char/short int/int类型指针在小/大端模式。

2.(Li/HW/W) : 小/半字/字

(Bi/HW/W) : 大/半字/字

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分