CN115437988A - 一种i2s音频时钟数据的同步方法、装置及应用 - Google Patents

一种i2s音频时钟数据的同步方法、装置及应用 Download PDF

Info

Publication number
CN115437988A
CN115437988A CN202110644352.0A CN202110644352A CN115437988A CN 115437988 A CN115437988 A CN 115437988A CN 202110644352 A CN202110644352 A CN 202110644352A CN 115437988 A CN115437988 A CN 115437988A
Authority
CN
China
Prior art keywords
data
frame
audio data
chip
cpu
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN202110644352.0A
Other languages
English (en)
Inventor
汪卫章
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Beijing Shikuang Technology Co ltd
Original Assignee
Beijing Shikuang Technology Co ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Beijing Shikuang Technology Co ltd filed Critical Beijing Shikuang Technology Co ltd
Publication of CN115437988A publication Critical patent/CN115437988A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/38Information transfer, e.g. on bus
    • G06F13/42Bus transfer protocol, e.g. handshake; Synchronisation
    • G06F13/4282Bus transfer protocol, e.g. handshake; Synchronisation on a serial bus, e.g. I2C bus, SPI bus
    • G06F13/4295Bus transfer protocol, e.g. handshake; Synchronisation on a serial bus, e.g. I2C bus, SPI bus using an embedded synchronisation

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Synchronisation In Digital Transmission Systems (AREA)

Abstract

本发明提供了一种I2S音频时钟数据的同步方法、装置及应用,将没有slave模式的CPU的I2S音频数据流,切分成多帧的音频数据,在帧数据之间***全为0的比特流数据,并在每帧音频数据上加上帧头,形成新的帧数据,发送给FGPA芯片;FGPA芯片接收到帧数据后,去掉帧头和空闲数据,得到新的音频数据;同时,FGPA芯片根据本地的晶振或时钟向CPU产生一个TIME信号,促使CPU同步向FGPA芯片发送的音频数据量,并将新的音频数据写入FIFO芯片;FPGA芯片按照本地的时钟或晶振,向数模转换器产生BCK数据和LRCK数据,并读取FIFO芯片中的音频数据送给数模转换器。本发明的同步方法,实现没有slave模式的CPU的I2S音频数据的时钟信息与FGPA芯片时钟数据的同步,实现了以更高的品质播放音乐文件的目的。

Description

一种I2S音频时钟数据的同步方法、装置及应用
技术领域
本申请涉及音频通信技术领域,尤其涉及一种I2S音频时钟数据的同步方法、装置及应用。
背景技术
大规模集成电路的迅速发展与广泛应用,使得数字***的复杂程度大大增加,导致其设计、开发、检测和故障诊断越来越复杂。在实际应用中,不少CPU提供i2S接口,但有部分CPU的I2S没有slave(从)模式,只有master(主)模式,即i2S的时钟由CPU的主时钟经过PLL变换而来。在这种情况下,音频***的时钟频偏一般较大,抖动也较大。因此,用传统有限的I2S音频时钟数据的方法已经远远不能满足用户的需求。
对于现有的没有slave模式的CPU的I2S音频数据,无法在传输到FGPA芯片时,达到与FGPA芯片的时钟数据信息的同步,进而导致了CPU没有slave模式的CPU的I2S音频数据的时钟信号和FGPA芯片的时钟信号的不同步,无法进行各类音乐文件的高品质播放。
因此,亟需开发一种I2S音频时钟数据的同步方法、装置及应用,解决现有产品开发中存在的技术难题。
发明内容
为解决现有技术存在的没有slave模式的CPU的I2S音频数据,无法在传输到FGPA芯片时,达到与FGPA芯片的时钟数据信息的同步,也因而无法实现各类音乐文件的高品质播放的技术难题,本发明开发了一种I2S音频时钟数据的同步方法、装置及应用,有效地解决该技术难题。本发明开发的I2S音频时钟数据的同步方法,可实现所述没有slave模式的CPU的I2S音频数据传输到所述FGPA芯片时,对所述I2S音频数据的时钟信息的同步,进而实现更准确的时钟信号,达到了可以以更高的品质播放各类音乐文件的目的。
本发明第一方面开发一种I2S音频时钟数据的同步方法,所述的同步方法包括:
步骤一、将没有slave模式的CPU的I2S音频数据流进行预处理:
将没有slave模式的CPU的I2S音频数据流,切分成一帧一帧的音频数据;
在每一帧的音频数据(包括n个字,n>1)上加上帧头,形成长度为n+1个字的帧数据;所述的帧头包括帧数据长度和CRC校验长度;
步骤二、所述没有slave模式的CPU向接收端FGPA芯片发送所述的长度为n+1个字的帧数据;
同时,所述接收端FGPA芯片根据本地的晶振或时钟,向所述没有slave模式的CPU产生一个TIME信号,所述的没有slave模式的CPU检测到所述的TIME信号后,同步向所述接收端FGPA芯片发送的音频数据量;
步骤三、所述接收端FGPA芯片对接收到的所述的长度为n+1个字的帧数据,去掉所述帧头和空闲数据后,得到新的音频数据;将所述的新的音频数据写入FIFO芯片;
步骤四、所述的FPGA芯片按照设置在FPGA芯片上的时钟或晶振,向数模转换器产生第二BCK数据和第二LRCK数据,并从所述的FIFO芯片中读取步骤三所述的新的音频数据送给所述数模转换器。
优选地,所述的没有slave模式的CPU的I2S音频数据流包括第一BCK数据和第一LRCK数据,所述的第一BCK数据和第一LRCK数据,是由所述没有slave模式的CPU的内部时钟锁相生成。
更优选地,在所述的一帧一帧的音频数据之间***全为0的比特流数据或不***全为0的比特流数据。
更优选地,所述的全为0的比特流数据的长度,可实现以下功能:使得所述长度为n+1个字的帧中音频数据的速率和FPGA芯片的时钟所要求的音频数据的速率相同。
更优选地,步骤二所述的同步的方法包括:步骤二所述的同步的方法包括:如果所述接收端FGPA芯片连续收到三帧(帧中间可能有或没有全为0的比特流数据)的所述长度为n+1个字的一帧数据的包头CRC校验正确,那么接收端FGPA芯片将进入同步状态,从而正确获取所需的音频数据。
本发明第二方面开发一种I2S音频时钟数据的同步装置,所述的同步装置包括没有slave模式的CPU、FGPA芯片、FIFO芯片和数模转换器;设置从所述的没有slave模式的CPU的I2S音频数据流获取的音频时钟数据(第一BCK数据和第一LRCK数据),使所述的第一BCK数据和第一LRCK数据频率大于所述FPGA芯片的本振频率;所述没有slave模式的CPU向所述FGPA芯片发送长度为n+1个字的帧数据,n>1;所述FGPA芯片接收到所述的长度为n+1个字的帧数据的同时,根据本地的晶振或时钟,向所述没有slave模式的CPU发送TIME信号,促使所述的没有slave模式的CPU同步向所述接收端FGPA芯片发送的音频数据量;所述FGPA芯片接收到所述的长度为n+1个字的帧数据后,去掉帧头和空闲数据得到新的音频数据,将所述的新的音频数据写入FIFO芯片;所述的FPGA芯片根据本地的晶振或时钟,向所述数模转换器产生第二BCK数据和第二LRCK数据,并从所述的FIFO芯片中读取所述的新的音频数据发送给所述的数模转换器。
优选地,所述长度为n+1个字的帧数据的获取方法为:将没有slave模式的CPU的I2S音频数据流,切分成一帧一帧的音频数据;在每一帧的音频数据(包括n个字,n>1)上加上帧头,形成长度为n+1个字的帧数据;所述的帧头帧数据长度和CRC校验长度。
更优选地,在所述的一帧一帧的音频数据之间***全为0的比特流数据或不***全为0的比特流数据。
更优选地,所述的全为0的比特流数据的长度,可实现以下功能:使得所述长度为n+1个字的帧数据的速率和FPGA芯片的时钟数据的速率相同。
本发明第三方面一种前述的方法、或者前述的同步装置在音乐播放上的应用。
本发明的技术效果:通过本发明开发的I2S音频时钟数据的同步方法、装置及应用,有效地实现所述没有slave模式的CPU的I2S音频数据传输到所述FGPA芯片时,对所述I2S音频数据的时钟信息的同步,进而实现更准确的时钟信号,达到可以以更高的品质播放各类音乐文件的目的。
附图说明
此处所说明的附图用来提供对本申请的进一步理解,构成本申请的一部分,本申请的示意性实施例及其说明用于解释本申请,并不构成对本申请的不当限定。在附图中:
图1示出了本发明的***示意图;
图2示出了本发明的数据帧结构;其中,Ln表示左声道,Rn表示右声道。
具体实施方式
下面通过具体实施方式结合附图对本发明作进一步详细说明。其中不同实施方式中类似元件采用了相关联的类似的元件标号。在以下的实施方式中,很多细节描述是为了使得本申请能被更好的理解。然而,本领域技术人员可以毫不费力的认识到,其中部分特征在不同情况下是可以省略的,或者可以由其他元件、材料、方法所替代。在某些情况下,本申请相关的一些操作并没有在说明书中显示或者描述,这是为了避免本申请的核心部分被过多的描述所淹没,而对于本领域技术人员而言,详细描述这些相关操作并不是必要的,他们根据说明书中的描述以及本领域的一般技术知识即可完整了解相关操作。
另外,说明书中所描述的特点、操作或者特征可以以任意适当的方式结合形成各种实施方式。同时,方法描述中的各步骤或者动作也可以按照本领域技术人员所能显而易见的方式进行顺序调换或调整。因此,说明书和附图中的各种顺序只是为了清楚描述某一个实施例,并不意味着是必须的顺序,除非另有说明其中某个顺序是必须遵循的。
本文中为部件所编序号本身,例如“第一”、“第二”等,仅用于区分所描述的对象,不具有任何顺序或技术含义。而本申请所说“连接”、“联接”,如无特别说明,均包括直接和间接连接(联接)。
在本发明中,如果没有特殊说明,所述的TIME信号是指FPGA芯片产生的与FPGA芯片相连的高品质晶振分频获得的一种低频信号。
为清楚地理解本申请的技术内容,这里将对一些技术术语进行说明。
I2S信号(Inter-IC Sound信号),是飞利浦公司针对数字音频设备(如CD播放器、数码音效处理器、数字电视音响***)之间的音频数据传输而制定的一种总线标准。它通过将数据信号和时钟信号相分离的设计方式避免了因时差诱发的失真。传输I2S信号的标准总线电缆是由3根串行导线组成的:1根是时分多路复用数据线,1根是字选择线;1根是时钟线。 那么,I2S信号主要包括帧时钟信号(LRCK)、串行时钟信号(BCK或SCLK)和串行数据信号(DATA或SDATA);其中,LRCK用于切换左右声道的数据,高电平(即为“1”)时表示传输右声道数据,低电平(即为“0”)时表示传输左声道数据,LRCK的频率等于采样频率;其中,BCK的每一个脉冲对应数字音频的每一位数据,BCK的频率=2 *采样频率*采样位深;其中,DATA就是用二进制补码表示的音频数据,往往是最高有效位MSB到最低有效位 LSB依次传输。
本发明提供了一种I2S音频时钟数据的同步方法,属于音频通信技术领域,所述的同步方法包括:将没有slave模式的CPU的I2S音频数据流,切分成一帧一帧的音频数据,在所述的一帧一帧的音频数据之间***全为0的比特流数据;同时,在每一帧的音频数据上加上帧头,形成长度为n+1个字的帧数据,所述没有slave模式的CPU向接收端FGPA芯片发送所述的长度为n+1个字的帧数据;同时,所述接收端FGPA芯片向所述没有slave模式的CPU产生一个TIME信号,所述的没有slave模式的CPU检测到所述的TIME信号后,同步向所述接收端FGPA芯片发送的音频数据量;所述接收端FGPA芯片对接收到的所述的长度为n+1个字的帧数据,去掉所述帧头和空闲数据后,得到新的音频数据;将所述的新的音频数据写入FIFO芯片;所述的FPGA芯片按照设置在FPGA芯片上的时钟或晶振,向数模转换器产生第二BCK数据和第二LRCK数据,并从所述的FIFO芯片中读取步骤三所述音频数据送给所述数模转换器。本发明开发的I2S音频时钟数据的同步方法,可实现所述没有slave模式的CPU的I2S音频数据传输到所述FGPA芯片时,对所述I2S音频数据的时钟信息的同步,进而实现更准确的时钟信号,达到了可以以更高的品质播放各类音乐文件的目的。
下面将结合实施例对本申请技术方案进行详细说明。
本发明提供了一种I2S音频时钟数据的同步方法、装置及应用,将没有slave模式的CPU的I2S音频数据流切分成多帧的音频数据,在帧数据之间***全为0的比特流数据,并在每帧n个字的音频数据上加上帧头,形成长度为n+1个字的帧数据,发送给FGPA芯片(在本发明中,根据音频数据通道位宽,每帧的音频数据的长度一般为32BIT或24BIT。每个字含有左右声道的数据,即为2*32=64BIT或2*24=48BIT);FGPA芯片对接收到的帧数据,去掉帧头和空闲数据后,得到新的音频数据;同时,FGPA芯片根据本地的晶振或时钟向CPU产生一个TIME信号,促使CPU同步向FGPA芯片发送的音频数据量;FPGA将新的音频数据写入FPGA内部的FIFO芯片;FPGA芯片按照本地的时钟或晶振,向数模转换器产生BCK数据和LRCK数据,并读取音频数据送给所述数模转换器。本发明的同步方法,实现没有slave模式的CPU的I2S音频数据的时钟信息与FGPA芯片时钟数据的同步,实现了以更高的品质播放音乐文件的目的。
实施例1、一种I2S音频时钟数据的同步方法
本实施例提供了一种I2S音频时钟数据的同步方法,如图1和图2所示,所述的同步方法包括:
步骤一、将没有slave模式的CPU的I2S音频数据流进行预处理:
设置从所述的没有slave模式的CPU的I2S音频数据流获取的音频时钟数据(第一BCK数据和第一LRCK数据),使所述的第一BCK数据和第一LRCK数据频率大于所述FPGA芯片的本振频率。
将没有slave模式的CPU的I2S音频数据流切分成一帧一帧的音频数据(每帧音频数据包括n个字,n>1),在每一帧的音频数据上加上帧头,形成长度为n+1个字的一帧数据(在本发明中,根据音频数据通道位宽,每帧的音频数据的长度一般为32BIT。每个字含有左右声道的数据,即为2*32=64BIT);其中,所述帧头包括两个部分:一部分为帧数据长度,所述帧数据长度是以字为单位;另一部分为CRC校验长度;其中,所述的没有slave模式的CPU的I2S音频数据流包括第一BCK数据和第一LRCK数据,所述的第一BCK数据和第一LRCK数据,是由所述没有slave模式的CPU的内部时钟锁相生成。
在所述一帧一帧的音频数据之间可以***全0字,全0字为一串全为0的比特流,0的个数为N个字,表示空数据;***全0字的长度是根据TIME的要求***正常的音频数据后在多余的时钟空间内***空闲,使得所述长度为n+1个字的帧中音频数据的速率和FPGA芯片的时钟所要求的音频数据的速率相同。比如,假设TIME信号为10HZ变化一次,如果所述没有slave模式的CPU的音频数据的频率为44.1Khz;则所述没有slave模式的CPU每检测到一次TIME变化,所述没有slave模式的CPU向所述接收端FGPA芯片发送4410次左右音频数据,由于所述没有slave模式的CPU产生的BCK数据和LRCK数据的频率会更高一些,在所述没有slave模式的CPU向所述接收端FGPA芯片发送音频数据中间会间插空闲数据,从而使使得所述长度为n+1个字的一帧数据中音频数据的速率和FPGA芯片的时钟所要求的音频数据的速率相同。
步骤二、所述接收端FGPA芯片根据本地的晶振或时钟,向所述没有slave模式的CPU产生一个TIME信号,所述没有slave模式的CPU检测到所述TIME信号后,同步向所述接收端FGPA芯片发送的数据量(在此处,同步的方法包括但不限于:如果所述没有slave模式的CPU连续收到三帧的CRC都正确,即实现同步)。
其中,所述没有slave模式的CPU的I2S音频数据流包括第一BCK数据和第一LRCK数据,所述第一BCK数据和第一LRCK数据是由所述没有slave模式的CPU的内部时钟锁相生成。
步骤三、所述没有slave模式的CPU,将步骤一所述长度为n+1个字的一帧数据发送给步骤二所述接收端FGPA芯片,如果所述接收端FGPA芯片连续收到三帧的所述长度为n+1个字的一帧数据的包头CRC校验正确,那么接收端FGPA芯片将跳过帧中间可能存在的全0字,即进入同步状态,进入同步。
所述接收端FGPA芯片对接收到的所述长度为n+1个字的帧(n>1)数据,去掉所述帧头和空闲数据后,得到新的音频数据;FPGA芯片将所述的新的音频数据写入FPGA芯片内部的FIFO芯片。
步骤四、所述FPGA芯片按照设置在FPGA芯片上的时钟或晶振,向数模转换器(DAC)产生BCK数据和LRCK数据,并从所述FIFO芯片中读取步骤三所述音频数据送给所述数模转换器(DAC),完成数据传输。
本实施例开发了一种I2S音频时钟数据的同步方法,实现了所述没有slave模式的CPU的音频时钟数据和所述FGPA芯片时钟数据的同步,实现了音乐播放时的高品质播放的功能。
实施例2、一种I2S音频时钟数据的同步装置
本实施例开发了一种I2S音频时钟数据的同步装置,所述的同步装置包括没有slave模式的CPU、FGPA芯片、FIFO芯片和数模转换器。
将没有slave模式的CPU的I2S音频数据流切分成一帧一帧的音频数据(每帧音频数据包括n个字,n>1),在所述的一帧一帧的音频数据之间***全为0的比特流数据。所述的全为0的比特流数据的长度,可实现以下功能:使得所述长度为n+1个字的帧数据的速率和FPGA芯片的时钟数据的速率相同(在本发明中,根据音频数据通道位宽,每帧的音频数据的长度一般为24BIT。每个字含有左右声道的数据,即为2*24=48BIT)。
在每一帧的音频数据上加上帧头,形成长度为n+1个字的一帧数据,n>1;所述帧头包括两个部分:一部分为帧数据长度,所述帧数据长度是以字为单位;另一部分为CRC校验长度;所述的没有slave模式的CPU的I2S音频数据流包括第一BCK数据和第一LRCK数据,所述的第一BCK数据和第一LRCK数据,是由所述没有slave模式的CPU的内部时钟锁相生成。
所述没有slave模式的CPU向所述FGPA芯片发送长度为n+1个字的帧数据;所述FGPA芯片接收到所述的长度为n+1个字的帧数据的同时,并根据本地的晶振或时钟,向所述没有slave模式的CPU发送TIME信号,促使所述的没有slave模式的CPU同步向所述接收端FGPA芯片发送的音频数据量;所述FGPA芯片接收到所述的长度为n+1个字的帧数据后,去掉帧头和空闲数据得到新的音频数据,将所述的新的音频数据写入FPGA芯片内部的FIFO芯片。
所述的FPGA芯片按照设置在FPGA芯片上的时钟或晶振,向所述数模转换器发送BCK数据和LRCK数据,并从所述的FIFO芯片中读取所述的音频数据发送给所述的数模转换器。
本实施例开发了一种I2S音频时钟数据的同步装置,实现了所述没有slave模式的CPU的音频时钟数据和所述FGPA芯片时钟数据的同步,实现了音乐播放时的高品质播放的功能。
本领域内的技术人员应明白,本申请的实施例可提供为方法、***、或计算机程序产品。因此,本申请可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本申请可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本申请是参照根据本申请实施例的方法、设备(***)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
尽管已描述了本申请的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例作出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本申请范围的所有变更和修改。
本领域技术人员可以理解,上述实施方式中各种方法的全部或部分功能可以通过硬件的方式实现,也可以通过计算机程序的方式实现。当上述实施方式中全部或部分功能通过计算机程序的方式实现时,该程序可以存储于一计算机可读存储介质中,存储介质可以包括:只读存储器、随机存储器、磁盘、光盘、硬盘等,通过计算机执行该程序以实现上述功能。例如,将程序存储在设备的存储器中,当通过处理器执行存储器中程序,即可实现上述全部或部分功能。另外,当上述实施方式中全部或部分功能通过计算机程序的方式实现时,该程序也可以存储在服务器、另一计算机、磁盘、光盘、闪存盘或移动硬盘等存储介质中,通过下载或复制保存到本地设备的存储器中,或对本地设备的***进行版本更新,当通过处理器执行存储器中的程序时,即可实现上述实施方式中全部或部分功能。
以上应用了具体个例对本发明进行阐述,只是用于帮助理解本发明,并不用以限制本发明。对于本发明所属技术领域的技术人员,依据本发明的思想,还可以做出若干简单推演、变形或替换。

Claims (10)

1.一种I2S音频时钟数据的同步方法,其特征在于,所述的同步方法包括:
步骤一、将没有slave模式的CPU的I2S音频数据流进行预处理:
将没有slave模式的CPU的I2S音频数据流,切分成一帧一帧的音频数据;
在每一帧的音频数据上加上帧头,形成长度为n+1个字的帧数据;其中,所述的每一帧的音频数据包括n个字,n>1;所述的帧头包括帧数据长度和CRC校验长度;
步骤二、所述没有slave模式的CPU向接收端FGPA芯片发送所述的长度为n+1个字的帧数据;
同时,所述接收端FGPA芯片根据本地的晶振或时钟,向所述没有slave模式的CPU产生一个TIME信号,所述的没有slave模式的CPU检测到所述的TIME信号后,同步向所述接收端FGPA芯片发送的音频数据量;
步骤三、所述接收端FGPA芯片对接收到的所述的长度为n+1个字的帧数据,去掉所述帧头和空闲数据后,得到新的音频数据;将所述的新的音频数据写入FIFO芯片;
步骤四、所述的FPGA芯片按照设置在FPGA芯片上的时钟或晶振,向数模转换器产生第二BCK数据和第二LRCK数据,并从所述的FIFO芯片中读取步骤三所述的新的音频数据送给所述数模转换器。
2.根据权利要求1所述的同步方法,其特征在于,所述的没有slave模式的CPU的I2S音频数据流包括第一BCK数据和第一LRCK数据,所述的第一BCK数据和第一LRCK数据,是由所述没有slave模式的CPU的内部时钟锁相生成。
3.根据权利要求1或2所述的同步方法,其特征在于,在所述的一帧一帧的音频数据之间***全为0的比特流数据或不***全为0的比特流数据。
4.根据权利要求3所述的同步方法,其特征在于,所述的全为0的比特流数据的长度,可实现以下功能:使得所述长度为n+1个字的帧中音频数据的速率和FPGA芯片的时钟所要求的音频数据的速率相同。
5.根据权利要求3所述的同步方法,其特征在于,步骤二所述的同步的方法包括:如果所述接收端FGPA芯片连续收到三帧的所述长度为n+1个字的一帧数据的包头CRC校验正确,那么接收端FGPA芯片将进入同步状态。
6.一种I2S音频时钟数据的同步装置,其特征在于,所述的同步装置包括没有slave模式的CPU、FGPA芯片、FIFO芯片和数模转换器;
设置从所述的没有slave模式的CPU的I2S音频数据流获取的音频时钟数据,所述的音频时钟数据包括第一BCK数据和第一LRCK数据,使所述的第一BCK数据和第一LRCK数据频率大于所述FPGA芯片的本振频率;
所述没有slave模式的CPU向所述FGPA芯片发送长度为n+1个字的帧数据,n>1;所述FGPA芯片接收到所述的长度为n+1个字的帧数据的同时,根据本地的晶振或时钟,向所述没有slave模式的CPU发送TIME信号,促使所述的没有slave模式的CPU同步向所述接收端FGPA芯片发送的音频数据量;
所述FGPA芯片接收到所述的长度为n+1个字的帧数据后,去掉帧头和空闲数据得到新的音频数据,将所述的新的音频数据写入FIFO芯片;
所述的FPGA芯片根据本地的晶振或时钟,向所述数模转换器产生第二BCK数据和第二LRCK数据,并从所述的FIFO芯片中读取所述的新的音频数据发送给所述的数模转换器。
7.根据权利要求6所述的同步装置,其特征在于,所述长度为n+1个字的帧数据的获取方法为:将没有slave模式的CPU的I2S音频数据流,切分成一帧一帧的音频数据;在每一帧的音频数据上加上帧头,形成长度为n+1个字的帧数据;其中,所述的每一帧的音频数据包括n个字,n>1;所述的帧头包括帧数据长度和CRC校验长度。
8.根据权利要求7所述的同步装置,其特征在于,在所述的一帧一帧的音频数据之间***全为0的比特流数据或不***全为0的比特流数据。
9.根据权利要求7所述的同步装置,其特征在于,所述的全为0的比特流数据的长度,可实现以下功能:使得所述长度为n+1个字的帧数据的速率和FPGA芯片的时钟数据的速率相同。
10.一种根据权利要求4或5所述的方法、或者根据权利要求6至9任一权项所述的同步装置在音乐播放上的应用。
CN202110644352.0A 2021-06-04 2021-06-09 一种i2s音频时钟数据的同步方法、装置及应用 Pending CN115437988A (zh)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
CN2021106254162 2021-06-04
CN202110625416 2021-06-04

Publications (1)

Publication Number Publication Date
CN115437988A true CN115437988A (zh) 2022-12-06

Family

ID=84271797

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202110644352.0A Pending CN115437988A (zh) 2021-06-04 2021-06-09 一种i2s音频时钟数据的同步方法、装置及应用

Country Status (1)

Country Link
CN (1) CN115437988A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN117353858A (zh) * 2023-12-01 2024-01-05 深圳市维海德技术股份有限公司 音频时钟同步方法、***、设备及可读存储介质

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN117353858A (zh) * 2023-12-01 2024-01-05 深圳市维海德技术股份有限公司 音频时钟同步方法、***、设备及可读存储介质
CN117353858B (zh) * 2023-12-01 2024-03-19 深圳市维海德技术股份有限公司 音频时钟同步方法、***、设备及可读存储介质

Similar Documents

Publication Publication Date Title
US5764965A (en) Synchronization infrastructure for use in a computer system
US5245667A (en) Method and structure for synchronizing multiple, independently generated digital audio signals
JPH05219141A (ja) 制御及びステータス情報を受信しかつ送信するための回路及び方法
CN105027019B (zh) 用于usb***内的音频取样率转换器的弹性计时
US20030195645A1 (en) Circuits and methods for extracting a clock from a biphase encoded bit stream and systems using the same
CN107277594A (zh) 一种视音频与弹幕同步方法及装置
WO1999017290A1 (en) Sample rate conversion of non-audio aes data channels
CN110248285B (zh) 多声道音频设备
CN100354798C (zh) 预处理公共格式中央处理输入或输出信号的方法及设备
JP3270899B2 (ja) コンピュータシステムのメモリにオーディオ信号を記憶させる装置及び方法
US6804655B2 (en) Systems and methods for transmitting bursty-asnychronous data over a synchronous link
CN115437988A (zh) 一种i2s音频时钟数据的同步方法、装置及应用
US6067411A (en) Adaptive frequency synthesizer with synchronization
US6683927B1 (en) Digital data reproducing apparatus and method, digital data transmitting apparatus and method, and storage media therefor
JP2008005193A (ja) シリアル伝送システム、伝送装置、及びシリアル伝送方法
JP3451971B2 (ja) パケット転送装置
JP4011062B2 (ja) 信号伝送方法
JP7078842B2 (ja) 送信装置、受信装置、クロック転送方法およびプログラム
JP3351385B2 (ja) シリアルデータ送受信方法及び装置
JP3451973B2 (ja) パケット転送装置
JPH07176138A (ja) 高周波数動作用パイプラインデコーダ
JPWO2008035576A1 (ja) バッファリング制御方法、およびバッファリング制御装置
JP3444224B2 (ja) パケット転送装置
JP6473673B2 (ja) タイムコード伝送装置、方法及びプログラム
JP2822912B2 (ja) 遅延設定システム

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination