MM32F5270 系列控制器支持 I2S 總線接口,本章節在接下來會對 MM32F5270 I2S進行介紹,并使用 MM32F5270 和 CS4344 芯片進行 I2S 通信來演示播放一段聲音。
I2S 簡介
I2S ( Inter—IC Sound ) 總線是飛利浦公司為數字音頻設備之間的音頻數據傳輸而制定的一種總線標準,該總線專責于音頻設備之間的數據傳輸,廣泛應用于各種多媒體系統。它采用了沿獨立的導線傳輸時鐘與數據信號的設計,通過將數據和時鐘信號分離,避免了因時差誘發的失真,為用戶節省了購買抵抗音頻抖動的專業設備的費用。在飛利浦公司的 I2S 標準中,既規定了硬件接口規范,也規定了數字音頻數據的格式。
在 MM32F5270 中,SPI 與 I2S 共用引腳。在 I2S 的描述中,支持半雙工通信,也支持全雙工模式。I2S 與 SPI 區別在于,I2S 主模式的控制邏輯使用獨立的時鐘分頻處理單元。在半雙工模式下,可使用 MCK 引腳輸出驅動時鐘,用于驅動外部音頻組件。在全雙工模式下,為了能同時進行數據的收發,MCK 驅動時鐘只能從專用的 MCK 功能引腳輸出。I2S 的功能框圖如圖 1 所示,包括時鐘單元,寄存器控制單元,主從模式控制單元等。

圖1. I2S 功能框圖
MM32F5270 中 I2S 主要特征
支持半雙工通信(僅發射機或接收機)和全雙工通信(SD,extSD 的數據方向根據主/從模式配置決定)兩種通信方式
9 位可編程線性預分頻器,以達到精確的音頻采樣頻率( 8KHz 到 192KHz)
數據幀格式可以是 16 位、 24 位或 32 位
數據包幀固定為 16 位(16 位有效數據)或 32 位(16 位、 24 位、 32 位有效數據)
可編程時鐘極性(穩定狀態)
發射模式下的下溢標志(僅從機),接收模式下的上溢標志(主和從機)和接收/發射模式下的幀錯誤標志(僅從機)
用于傳輸和接收的 32 位寄存器為兩個聲道分時復用
支持 I2S 協議
飛利浦標準
MSB 對齊標準(左對齊)
LSB 對齊標準(右對齊)
PCM 標準(在 16 位信道幀上具有短幀和長幀同步或擴展到 32 位信道幀的 16 位數據幀)
數據方向始終是 MSB 優先
DMA 傳輸能力
可配置輸出 MCLK 來驅動外部音頻組件,比率固定在 256× FS(其中 FS 為音頻采樣頻率)
I2S 信號接口
I2S 和 SPI 共用三個公共管腳:
串行時鐘 CK
映射在 SCK 引腳上,也叫位時鐘 BCLK,是主模式下的串行時鐘輸出以及從機模式下的串行時鐘輸入。SCLK 頻率 = 2 x 采樣頻率 x 采樣位數
幀時鐘 WS
映射在 NSS 引腳上,是主模式下的串行時鐘輸出以及從機模式下的串行時鐘輸入。用于切換左右聲道,LRCK 頻率 = 采樣頻率
串行數據 SD
映射在 MOSI 管腳上,二進制補碼表示的音頻數據,用于發送或接收兩次多路數據通道(僅在半雙工模式下)。
當某些外部設備需要主時鐘輸入時,可以使用一個附加的管腳輸出時鐘到音頻設備
主時鐘 MCLK
映射在 MISO 引腳或專用 MCK 引腳上,當 I2S 配置為主模式時使用此時鐘。MCLK 頻率 = 256 x 采樣頻率 Fs
I2S 引腳信號如圖 2 所示。

圖2. I2S 引腳信號
數據格式
三線總線處理音頻數據,必須經過分時復用兩個聲道:右聲道和左聲道。因為只有一個 32 位寄存器用于傳輸或接收,所以軟件應依次配置寄存器 TXREG 為各聲道的數據,或依次讀取寄存器 RXREG 為各聲道的數據。按照 I2S 協議,總是先發送左聲道,然后發送右聲道。
數據格式可以采用以下格式進行發送:
16 位數據打包在 16 位幀中
16 位數據打包在 32 位幀中
24 位數據打包在 32 位幀中
32 位數據打包在 32 位幀中
當使用 32 位幀上發送 16 位數據時,前 16 位(MSB)是有效的位,16 位 LSB 制為 0,無需任何軟件操作,通過硬件實現,其他格式相似。
通信標準
I2S 接口支持四種音頻標準,通過配置寄存器 SPI_I2S_I2SCFGR 中的 I2SSTD[1:0]、PCMSYNC 位進行切換;數據格式則通過配置 DATLEN[1:0]、CHLEN 來進行選擇。對于所有通信標準及數據格式,總是先發送最高位(MSB 優先)。
飛利浦標準
對于飛利浦標準,WS 信號用于指示正在傳輸的聲道。發射器在 CK 的下降沿鎖存數據,接收器并在 CK 的上升讀取數據。WS 信號也在 CK 的下降沿被鎖定。對于這種標準 I2S 格式的信號,無論有多少位有效數據,數據的最高位總是出現在 WS 變化(也就是一幀開始)后的第 2 個 CK 脈沖處,如圖 3 所示。

圖3. 飛利浦標準示意圖
MSB 對齊標準
對于 MSB 對齊標準,第一個數據在 WS 變化后的第一個沿有效,如圖 4 所示。

圖4. MSB 對齊標準示意圖
LSB 對齊標準
對于 LSB 對齊標準,每個數據包幀的最低有效位總(LSB 位)是出現在 WS 變化前的 1 個 CK 脈沖周期處,如圖 5 所示。

圖5. LSB 對齊標準示意圖
PCM 標準
對于 PCM 標準,不需要使用聲道信息。PCM 有兩個模式:短幀模式和長幀模式,通過配置SPI\_I2S\_I2SCFGR 寄存器的 PCMSYNC 位進行切換。在 PCM 模式下,輸出信號(WS, SD)在 CK 信號的上升沿進行采樣。輸入信號(WS, SD)在 CK 下降沿被捕獲。注意在主模式下, CK 和 WS 被配置為輸出,如圖 6 所示。

圖6. PCM 對齊標準示意圖
I2S 配置
I2S 的配置主要包括主從模式選擇,時鐘極性,全雙工半雙工模式選擇,采樣頻率和通信標準的配置,從而進行數據傳輸。
主模式
I2S 功能的主模式下,選擇全雙工工作時,SD 引腳作為主機發送接口,extSD 作為主機接收接口,SCK 和 WS作為主機的輸出信號,同時 MCK 向外部提供可選的驅動時鐘(配置 SPI_I2S_I2SCFGR.MCKOE 位為 ‘1’ 使能 MCK 輸出),如圖 7 所示。

圖7. I2S 主模式全雙工通信
基于 MM32F5270 的聲音播放實驗
CS4344 芯片是實現本次實驗功能的重要器件之一。CS4344 是一種立體聲音頻數模轉換器 (DAC) ,可使用單個 +3.3 V 或 +5 V 電源,僅需要最小的支持電路。該系列線性模擬低通濾波器和自動速度模式檢測,當自動選擇 2 kHz 和 200 kHz 之間的采樣率,使用采樣率和主時鐘速率方法。
本實驗的基本原理是 MM32F3270 讀取正弦波采樣計算出的左右聲道的數組數據,通過 I2S 接口將 PCM 信號傳輸給 CS4344,再經過 TS4871(音頻功率放大器)連接到耳機接口,可以接入耳機等音頻播放裝置。
硬件設計
如圖 8-9 是 PLUS-F5270 的 I2S 電路部分,完整原理圖可以通過官網下載。其中,引腳信號對應分別為:
I2S2_SD 對應于引腳 E6
I2S2_CK 對應于引腳 D3
I2S2_WS 對應于引腳 E4
I2S2_MCK 對應于引腳 E5

圖8. I2S 電路圖(1)

圖9. I2S 電路圖(2)
GPIO 初始化 BOARD_InitPins()
配置 I2S 引腳,I2S_CK 為 PD3 引腳,I2S_SD 為 PE6 引腳,I2S_WS 為 PE4 引腳,I2S_MCK 為 PE5 引腳,復用通道為 AF5 。
voidBOARD_InitPins(void)
{
/*PB7-UART1_TX.*/
GPIO_Init_Typegpio_init;
gpio_init.Pins=GPIO_PIN_6;
gpio_init.PinMode=GPIO_PinMode_AF_PushPull;//GPIO_PinMode_AF_PushPull
gpio_init.Speed=GPIO_Speed_50MHz;
GPIO_Init(GPIOB,&gpio_init);
GPIO_PinAFConf(GPIOB,gpio_init.Pins,GPIO_AF_7);
/*PB6-UART1_RX.*/
gpio_init.Pins=GPIO_PIN_7;
gpio_init.PinMode=GPIO_PinMode_In_Floating;//GPIO_PinMode_In_Floating
gpio_init.Speed=GPIO_Speed_50MHz;
GPIO_Init(GPIOB,&gpio_init);
GPIO_PinAFConf(GPIOB,gpio_init.Pins,GPIO_AF_7);
/*PD3-I2S_CK.*/
gpio_init.Pins=GPIO_PIN_3;
gpio_init.PinMode=GPIO_PinMode_AF_PushPull;//GPIO_PinMode_In_PushPull
gpio_init.Speed=GPIO_Speed_10MHz;
GPIO_Init(GPIOD,&gpio_init);
GPIO_PinAFConf(GPIOD,gpio_init.Pins,GPIO_AF_5);
/*PE6-I2S_SD.*/
gpio_init.Pins=GPIO_PIN_6;
gpio_init.PinMode=GPIO_PinMode_AF_PushPull;//GPIO_PinMode_In_PushPull
gpio_init.Speed=GPIO_Speed_10MHz;
GPIO_Init(GPIOE,&gpio_init);
GPIO_PinAFConf(GPIOE,gpio_init.Pins,GPIO_AF_5);
/*PE4-I2S_WS.*/
gpio_init.Pins=GPIO_PIN_4;
gpio_init.PinMode=GPIO_PinMode_AF_PushPull;//GPIO_PinMode_In_PushPull
gpio_init.Speed=GPIO_Speed_10MHz;
GPIO_Init(GPIOE,&gpio_init);
GPIO_PinAFConf(GPIOE,gpio_init.Pins,GPIO_AF_5);
/*PE5-I2S_MCK.*/
gpio_init.Pins=GPIO_PIN_5;
gpio_init.PinMode=GPIO_PinMode_AF_PushPull;//GPIO_PinMode_In_PushPull
gpio_init.Speed=GPIO_Speed_10MHz;
GPIO_Init(GPIOE,&gpio_init);
GPIO_PinAFConf(GPIOE,gpio_init.Pins,GPIO_AF_5);
}
I2S 配置初始化 app_i2s_master_init()
初始化 I2S,配置時鐘頻率、采樣率、數據長度、通信協議、傳輸模式及是否使能 MCLK 。
voidapp_i2s_master_init(void)
{
/*setupI2Smastermodule.*/
I2S_Master_Init_Typei2s_master_init;
i2s_master_init.ClockFreqHz=BOARD_I2S_FREQ;
i2s_master_init.SampleRate=BOARD_I2S_SAMPLE_RATE;
i2s_master_init.DataWidth=BOARD_I2S_DATA_WIDTH;
i2s_master_init.Protocol=BOARD_I2S_PROTOCOL;
i2s_master_init.EnableMCLK=true;
i2s_master_init.Polarity=BOARD_I2S_CPOL;
i2s_master_init.XferMode=I2S_XferMode_TxOnly;
I2S_InitMaster(BOARD_I2S_PORT,&i2s_master_init);
/*enableI2S.*/
I2S_Enable(BOARD_I2S_PORT,true);
}
Protocol
通信標準格式選擇,可選 I2S Philips 標準、左對齊標準、右對齊標準、 PCM 短幀標準或 PCM 長幀標準,它設定 SPI\_I2S\_I2SCFGR 寄存器 I2SSTD位和 PCMSYNC位的值。一般設置為 I2S Philips 標準即可。
DataWidth
數據格式選擇,設定有效數據長度和幀長度,可選標準 16bit 格式、擴展 16bit( 32bit 幀長度) 格式、 24bit 格式和 32bit 格式,它設定 SPI\_I2SCFGR 寄存器 DATLEN 位和CHLEN 位的值。對應 16bit 數據長度可選 16bit 或 32bit 幀長度,其他都是 32bit 幀長度。
EnableMCLK
主時鐘輸出使能控制,可選使能輸出或禁止輸出,它設定 SPI_I2SPR 寄存器 MCKOE 位的值。為提高系統性能一般使能主時鐘輸出。
SampleRate
采樣頻率設置,標準庫提供采樣采樣頻率選擇,分別為 4KHz、8kHz、 11kHz、12KHz、16kHz、22kHz、32kHz、44kHz、48kHz、96kHz、192kHz 以及默認 2Hz,它設定 SPI\_I2S\_SPBRG 寄存器的值。
Polarity
空閑狀態的 CK 線電平,可選高電平或低電平,它設定 SPI\_I2S\_CCTL 寄存器 CPOL位的值。一般設置為低電平即可。
左右聲道數據
采樣函數 f (t) = A *sin( B*t ) , t 為采樣時間,單位: s。采樣位寬為 16bit,采樣頻率為 8 khz,系數 A 為10000,B 為2000π。
/*i2sleftchannelxferdata.*/
constint16_tsound_buf_left[SOUND_BUF_SIZE]=
{
0,3535,5000,3535,0,-3535,-5000,-3535,
0,3535,5000,3535,0,-3535,-5000,-3535,
};
/*i2srightchannelxferdata.*/
constint16_tsound_buf_right[SOUND_BUF_SIZE]=
{
0,3827,7071,9238,10000,9238,7071,3827,
0,-3827,-7071,-9238,-10000,-9238,-7071,-3827
};
左右聲道數據傳輸
/*putdataintoleftchannel.*/
voidapp_i2s_put_data_left(void)
{
I2S_PutData(BOARD_I2S_PORT,(uint32_t)sound_buf_left[sound_buf_index_left]);
sound_buf_index_left++;
if(sound_buf_index_left>=SOUND_BUF_SIZE)
{
sound_buf_index_left=0;
}
}
/*putdataintorightchannel.*/
voidapp_i2s_put_data_right(void)
{
I2S_PutData(BOARD_I2S_PORT,(uint32_t)sound_buf_right[sound_buf_index_right]);
sound_buf_index_right++;
if(sound_buf_index_right>=SOUND_BUF_SIZE)
{
sound_buf_index_right=0;
}
}
main() 函數
main() 函數結合上述操作,串口打印 "i2s_master_basic" ,初始化 I2S 后,將發送數組數據到左右聲道緩沖區,進行聲音播放。
intmain(void)
{
BOARD_Init();
printf("i2s_master_basic.
");
app_i2s_master_init();
while(1)
{
while(0u!=(I2S_GetStatus(BOARD_I2S_PORT)&SPI_I2S_CSTAT_TXFULL_MASK))
{}
app_i2s_put_data_left();/*sendingleftchanneldata.*/
while(0u!=(I2S_GetStatus(BOARD_I2S_PORT)&SPI_I2S_CSTAT_TXFULL_MASK))
{}
app_i2s_put_data_right();/*sendingrightchanneldata.*/
}
}
實驗演示
本實驗以搭載 MM32F5277E9PV 的 PLUS-F5270 開發板為平臺,其揚聲器將會播放左聲道數據,演示視頻如下:演示1. 播放左聲道數據
音響數據的采集、處理和傳輸是多媒體技術的重要組成部分。眾多的數字音頻系統已經進入消費市場,例如數字音頻錄音帶、數字聲音處理器。對于設備和生產廠家來說,標準化的信息傳輸結構可以提高系統的適應性。
本文介紹了 MM32F5270 中通過 I2S 和 CS4344 芯片進行通信來演示播放一段聲音,后續將進行 MP3 的播放,未完待續!
審核編輯:湯梓紅
-
控制器
+關注
關注
114文章
16960瀏覽量
182884 -
總線接口
+關注
關注
0文章
90瀏覽量
31037 -
I2S
+關注
關注
1文章
71瀏覽量
42646 -
MM32
+關注
關注
1文章
108瀏覽量
1018
原文標題:靈動微課堂 (第230講) | 基于MM32F5270的I2S音頻播放
文章出處:【微信號:MindMotion-MMCU,微信公眾號:靈動MM32MCU】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
基于MM32F5270開發板獲取雨滴傳感器的數據相關資料介紹
聊聊 MM32F5270是如何通過高并行度的總線設計實現系統吞吐率的最大化的
在MM32F5270開發板上播放TF卡WAV格式音樂
【MM32F5270】Keil開發環境搭建

使用STM32L1xx微控制器與外部I2S音頻編解碼器播放音頻文件

評論