12.同步串行接口(SSP)
12.1.模塊介紹
SPI_IIC 模塊可用作 SPI接口通信和 IIC接口通信,兩種功能同一時間只能選擇其中一種使用。該模塊集成兩種接口協(xié)議,節(jié)省資源的同時又能滿足不同的應(yīng)用需求。
12.2.功能特點
12.2.1. SPI功能
? 支持主模式和從模式工作
? 支持 1~32bit傳輸
? 支持 5byte發(fā)送/接收數(shù)據(jù)緩沖
? 傳輸數(shù)據(jù)順序 MSB和 LSB
? 支持標準模式,三線模式
? 可觸發(fā)中斷的專用發(fā)送和接收標志
12.2.2. IIC功能
? 支持主模式和從模式
? 主模式支持時鐘同步和總線仲裁
? 從模式支持在發(fā)送數(shù)據(jù)沒有準備好或者接收緩沖器滿時候拉低 SCL
? 從模式支持 7bit地址或者 10bit地址
? 從模式支持接收廣播地址
? 支持 5byte發(fā)送/接收數(shù)據(jù)緩沖
12.3.功能說明
12.3.1. SPI工作模式
? 模式 0:時鐘空閑為 0,上升沿采樣,下降沿出數(shù)據(jù)
? 模式 1:時鐘空閑為 0,下降沿采樣,上升沿出數(shù)據(jù)
? 模式 2:時鐘空閑為 1,下降沿采樣,上升沿出數(shù)據(jù)
? 模式 3:時鐘空閑為 1,上升沿采樣,下降沿出數(shù)據(jù)
12.3.2. SPI接口模式
? 標準模式:通信線有 CLK,CS,IO0(MOSI),IO1(MISO),一個 CLK傳輸 1bit數(shù)據(jù)
? 三線模式:通信線有 CLK,CS,IO0,接收和發(fā)送都通過 IO0,一個 CLK傳輸 1bit數(shù)據(jù)12.3.3. SPI數(shù)據(jù)幀與內(nèi)部緩存
SPI可支持 1~32bit幀數(shù)據(jù)傳輸,內(nèi)部集成了一個 40bit的緩沖區(qū),根據(jù)配置的數(shù)據(jù)幀長度不同,緩沖區(qū)能緩存的幀數(shù)也不一樣。數(shù)據(jù)幀長度<=8bit?時,緩沖區(qū)可容納 5?幀數(shù)據(jù),8bit<數(shù)據(jù)幀長度<=16bit時,緩沖區(qū)可容納兩幀數(shù)據(jù),數(shù)據(jù)幀長度>16bit時,緩沖區(qū)可容納 1幀數(shù)據(jù),當緩沖區(qū)無法再容下一幀數(shù)據(jù)時,緩沖區(qū)滿標志會置 1。
12.3.4. IIC主機時鐘同步和總線仲裁
IIC主機模式時,在多主機的應(yīng)用場景下,支持時鐘同步和總線仲裁。當總線上連接了不止一個主機時,就會存在同時發(fā)起通信的情況,這時候需要時鐘同步以及總線仲裁機制決定由哪個主機占用總線完成數(shù)據(jù)傳輸。
時鐘同步的原理:IIC總線上的不同主機可能發(fā)起傳輸時的時鐘頻率不一樣,通過時鐘同步機制,可以讓所有主機的時鐘同步,才能進行逐位仲裁。所有主機的 SCL在總線上是線與的關(guān)系,當總線上的 SCL由高切換到低電平時,所有主機從 0開始計算低電平周期時間。當電平時間達到時,如果總線上的其它主機的 SCL低電平仍然保持,那么其它主機進入高電平等待狀態(tài),等低電平時間最長的主機的 SCL拉高時再統(tǒng)一拉高。因此,總線上同步后的 SCL的低電平時間由低電平周期最長的主機決定,而高電平時間由高電平周期最短的主機決定。總線仲裁原理:IIC總線上不同主機的 SDA線也是線與的關(guān)系,各主機在 SCL線為高電平時,檢查SDA線的電平是否和自己發(fā)送的 SDA信號一致,如果檢測到 SDA線為低電平時,自己要發(fā)送的 SDA信號為高電平,那么該主機仲裁失敗,停止總線上的傳輸動作。
12.3.5. IIC從機拉低 SCL
IIC從機在發(fā)送狀態(tài)下如果緩沖區(qū)中沒有可發(fā)送的數(shù)據(jù),或者在接收狀態(tài)下緩沖區(qū)已滿時,將會在 SCL端口輸出低電平,拉低總線上的 SCL信號使主機暫停發(fā)送時鐘。當從機準備好發(fā)送或者接收后,將在 SCL輸出高電平,主機又可以重新控制總線上的 SCL線,恢復數(shù)據(jù)傳輸。
12.3.6. IIC從機支持 7bit/10bit尋址
IIC從機支持 7bit或者 10bit尋址模式,由寄存器 CON0的 IIC_SLAVE_ADDR_WIDTH位決定。7bit模式下,主機需要在 TX模式下發(fā)送帶 START位的 7bit地址,最后 1bit為 R/W標志。當主機寫從機時,尋址完成即可進行數(shù)據(jù)發(fā)送。當主機讀從機時,尋址完成后,主機需要改成 RX模式,然后配置準備接收的數(shù)據(jù)長度(寄存器 DMA_LEN),然后對寄存器 CMD_DATA寫任意值啟動接收。10bit模式下,主機需要在 TX模式下發(fā)送帶 START位的第 1byte地址(此時 R/W位為 1),接著發(fā)送第 2byte地址,此時如果收到從機的 ACK信號,則為尋址成功。接下來如果是主機寫從機,就可以直接進行數(shù)據(jù)發(fā)送。如果是主機讀從機,那么需要主機再次發(fā)送帶 START為的第 1byte地址(此時 R/W為 1),然后切換成 RX模式,配置寄存器 DMA_LEN,并且對寄存器 CMD_DATA寫任意值啟動讀數(shù)據(jù)。
主機讀從機時,從機被尋址成功且收到讀標志時,需要切換成 TX模式,并且往緩沖區(qū)中寫入要發(fā)送的數(shù)據(jù)。
審核編輯:湯梓紅
-
芯片
+關(guān)注
關(guān)注
456文章
50963瀏覽量
424807 -
單片機
+關(guān)注
關(guān)注
6039文章
44582瀏覽量
636491 -
mcu
+關(guān)注
關(guān)注
146文章
17185瀏覽量
351703 -
接口
+關(guān)注
關(guān)注
33文章
8650瀏覽量
151409 -
SSP
+關(guān)注
關(guān)注
0文章
16瀏覽量
11584
發(fā)布評論請先 登錄
相關(guān)推薦
評論