91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

I2C總線的一種靈活控制方法

先楫半導(dǎo)體HPMicro ? 2023-07-11 10:01 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

I2C作為常用的通訊外設(shè),廣泛應(yīng)用在各種通訊場(chǎng)合,而且也衍生各種變體協(xié)議,比如SCCB,SMbus,PMbus等等。先楫半導(dǎo)體在I2C這個(gè)通訊外設(shè)上,每個(gè)傳輸?shù)碾A段都可以獨(dú)立自由去控制,這也極大得提高了開(kāi)發(fā)的自由靈活度,而且也可以隨性發(fā)揮生成I2C的變體協(xié)議,而不需要去進(jìn)行IO模擬。

首先介紹一下先楫半導(dǎo)體I2C的一些主要特性和功能,方便后續(xù)說(shuō)明,大家也可以到官網(wǎng)參考先楫用戶手冊(cè)。

1

I2C 特征

支持標(biāo)準(zhǔn)模式 (100Kb/s),快速模式 (400Kb/s) 和快速模式 +(1Mb/s)

可配置主從模式

支持 7 位和 10 位地址模式

支持廣播呼叫地址 (general call address)

自動(dòng)時(shí)鐘延展 (clock stretching)

可配置的時(shí)鐘/數(shù)據(jù)時(shí)序

支持直接內(nèi)存訪問(wèn) (DMA)

4 字節(jié) FIFO

2

I2C 功能

每個(gè)傳輸由 4 個(gè)階段組成:起始,地址,數(shù)據(jù)和結(jié)束。在起始階段會(huì)產(chǎn)生 START 操作,在地址階段發(fā)送地址,在數(shù)據(jù)階段 1 個(gè)或多個(gè)數(shù)據(jù)字節(jié)被傳送,在結(jié)束階段產(chǎn)生 STOP 操作。每個(gè)階段都能夠獨(dú)立控制是否執(zhí)行


4個(gè)字節(jié)FIFO,可不使用DMA的情況下,滿足多字節(jié)一次性傳輸。并且軟件沒(méi)有準(zhǔn)備好下一個(gè)字節(jié)的收發(fā)數(shù)據(jù)或者FIFO已滿時(shí)候,I2C控制器會(huì)自動(dòng)延展I2C總線時(shí)鐘來(lái)暫??偩€傳輸。


I2C控制器默認(rèn)使能了自動(dòng)ACK響應(yīng),即是除了最后一個(gè)字節(jié)外其余字節(jié)接收后都會(huì)自動(dòng)發(fā)出ACK,軟件可以使能字節(jié)接收中斷來(lái)禁止自動(dòng)響應(yīng)功能,軟件自己接收后決定是否發(fā)送ACK。

3

場(chǎng)合需求

在某些場(chǎng)合,當(dāng)I2C作為主機(jī)的時(shí)候,一次數(shù)據(jù)量傳輸當(dāng)中,可能會(huì)有以下的需求方式:


傳輸過(guò)程中間變化讀寫(xiě)方向,比如START操作到第一個(gè)數(shù)據(jù)字節(jié)傳輸是寫(xiě),后面變?yōu)樽x?;蛘咦x變成寫(xiě)。

傳輸過(guò)程中分三次傳輸,START,數(shù)據(jù),STOP傳輸。比如第一次傳輸需要帶START,但不需要STOP。

傳輸過(guò)程中需要restart重新發(fā)送start信號(hào)。

舉例,比如SMBUS,在進(jìn)行block read傳輸中,就需要傳輸過(guò)程中發(fā)送restart信號(hào),并且切換讀寫(xiě)方向。

df9ce2f8-1f8e-11ee-a579-dac502259ad0.png

4

實(shí)現(xiàn)方式

先楫半導(dǎo)體的用戶手冊(cè)對(duì)于 I2C 的寄存器說(shuō)明一共有好幾個(gè),本文重點(diǎn)介紹以下三個(gè)密切相關(guān)的寄存器:

1. CTRL寄存器:該寄存器是用來(lái)配置一次傳輸中的每個(gè)階段的控制,比如主機(jī)模式下,方向是發(fā)送,在START開(kāi)始后,STOP結(jié)束前,傳輸?shù)氖菙?shù)據(jù)段,可以不發(fā)START,地址,STOP。那么可以對(duì)其寄存器的對(duì)應(yīng)位進(jìn)行開(kāi)啟和關(guān)閉。

dfb5c3c2-1f8e-11ee-a579-dac502259ad0.pngdfd1f3d0-1f8e-11ee-a579-dac502259ad0.png

2. INTEN寄存器的BYTERECV位,開(kāi)啟或關(guān)閉自動(dòng)響應(yīng)功能。

dff1d25e-1f8e-11ee-a579-dac502259ad0.png

3. CMD寄存器:定義的是對(duì)一次transaction的相關(guān)操作。比如主機(jī)在接收到從機(jī)的數(shù)據(jù),需要不接受數(shù)據(jù)了,可以發(fā)送一個(gè)NACK響應(yīng)。前提是關(guān)閉了自動(dòng)響應(yīng)功能。

e0189970-1f8e-11ee-a579-dac502259ad0.pnge031b45a-1f8e-11ee-a579-dac502259ad0.png

根據(jù)以上的寄存器說(shuō)明,在新的sdk版本V1.2.0中,我們?cè)赟DK的i2c driver中看到有定義一個(gè)順序傳輸接口,定義一個(gè)枚舉,分別表示第一幀,中間幀,最后一幀。

/**

* @brief I2c sequentialtransfer options

* @arg: i2c_frist_frame: hasstart signal

* @arg: i2c_next_frame:middle transfer

* @arg: i2c_last_frame: hasstop signal

*/

typedef enum i2c_seq_transfer_opt{

i2c_frist_frame = 0,

i2c_next_frame,

i2c_last_frame,

}i2c_seq_transfer_opt_t;

對(duì)于發(fā)送接口,sdk1.2也提供了i2c_master_seq_transimit 這個(gè) API。

e0539016-1f8e-11ee-a579-dac502259ad0.png

對(duì)于接收接口,sdk1.2也提供了i2c_master_seq_receive這個(gè)API,從內(nèi)部API可以看出是關(guān)閉自動(dòng)響應(yīng),軟件控制一次傳輸?shù)腁CK和NACK,避免STOP未出現(xiàn)時(shí)出現(xiàn)數(shù)據(jù)斷開(kāi)。

e09b0810-1f8e-11ee-a579-dac502259ad0.png

5

驗(yàn)證功能

根據(jù)以上信息,我們來(lái)操作一個(gè)實(shí)驗(yàn),以sdk的poll例子的master和slave兩個(gè)開(kāi)發(fā)板進(jìn)行相互收發(fā),slave不做改動(dòng),master的讀寫(xiě)接口替換以上的接口。

int main(void)

{

hpm_stat_t stat;

i2c_config_t config;

uint32_t freq;

board_init();

init_i2c_pins(TEST_I2C);

config.i2c_mode = i2c_mode_normal;

config.is_10bit_addressing = false;

freq = clock_get_frequency(TEST_I2C_CLOCK_NAME);

stat = i2c_init_master(TEST_I2C, freq, &config);

if (stat != status_success) {

return stat;

}

printf("I2C polling master example\n");

prepare_tx_data();

uint32_t index = 0;

uint32_t inc_len = 30;

if (status_success != i2c_master_seq_transmit(TEST_I2C, TEST_I2C_SLAVE_ADDRESS, &tx_buff[index], inc_len, i2c_frist_frame)) {

printf("Master transfer frist frame failed\n");

while (1) {

}

}

index += inc_len;

if (status_success != i2c_master_seq_transmit(TEST_I2C, TEST_I2C_SLAVE_ADDRESS, &tx_buff[index], inc_len, i2c_next_frame)) {

printf("Master transfer next frame failed\n");

while (1) {

}

}

index += inc_len;

inc_len = (sizeof(tx_buff) - (inc_len * 2));

if (status_success != i2c_master_seq_transmit(TEST_I2C, TEST_I2C_SLAVE_ADDRESS, &tx_buff[index], inc_len, i2c_last_frame)) {

printf("Master transfer last frame failed\n");

while (1) {

}

}

/* wait for slave controller to be ready to send data */

board_delay_ms(100);

index = 0;

inc_len = 30;

if (status_success != i2c_master_seq_receive(TEST_I2C, TEST_I2C_SLAVE_ADDRESS, &rx_buff[index], inc_len, i2c_frist_frame)) {

printf("Master transfer read frist framefailed\n");

while (1) {

}

}

index += inc_len;

if (status_success != i2c_master_seq_receive(TEST_I2C, TEST_I2C_SLAVE_ADDRESS, &rx_buff[index], inc_len, i2c_next_frame)) {

printf("Master transfer read next framefailed\n");

while (1) {

}

}

index += inc_len;

inc_len = (sizeof(tx_buff) - (inc_len * 2));

if (status_success != i2c_master_seq_receive(TEST_I2C, TEST_I2C_SLAVE_ADDRESS, &rx_buff[index], inc_len, i2c_last_frame)) {

printf("Master transfer read last framefailed\n");

while (1) {

}

}

check_transfer_data();

while (1) {

}

return 0;

}

實(shí)驗(yàn)現(xiàn)象

①當(dāng)把一次完整傳輸拆分三次frame傳輸時(shí)候,依舊是沒(méi)什么問(wèn)題的??梢?jiàn)以上的功能使用并沒(méi)有什么問(wèn)題。

e0c8465e-1f8e-11ee-a579-dac502259ad0.png

② 可以模擬下一個(gè)配置錯(cuò)誤的現(xiàn)象,開(kāi)啟auto-ack功能,master接收slave數(shù)據(jù)的數(shù)據(jù),由于開(kāi)啟了自動(dòng)響應(yīng),在第一包frame接收的時(shí)候,I2C控制器認(rèn)為傳輸?shù)阶詈笠粋€(gè)字節(jié),會(huì)自動(dòng)補(bǔ)充N(xiāo)ACK,但我們并不希望補(bǔ)充N(xiāo)ACK,因?yàn)橐淮瓮暾膫鬏斶€沒(méi)完成,這時(shí)候就需要軟件自己添加ACK或者NACK。

e0ebb076-1f8e-11ee-a579-dac502259ad0.png

6

小 結(jié)

對(duì)于I2C,無(wú)論是poll方式,還是中斷方式,還是DMA方式,先楫的I2C控制器對(duì)于I2C傳輸?shù)拿總€(gè)階段都是可控的,這為開(kāi)發(fā)者的應(yīng)用需求也極大提高軟件靈活度。

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 總線
    +關(guān)注

    關(guān)注

    10

    文章

    3040

    瀏覽量

    91667
  • I2C
    I2C
    +關(guān)注

    關(guān)注

    28

    文章

    1556

    瀏覽量

    131245
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    探索PCF8584:I2C總線控制器的卓越之選

    探索PCF8584:I2C總線控制器的卓越之選 在電子工程師的日常工作中,選擇合適的芯片來(lái)實(shí)現(xiàn)特定功能至關(guān)重要。今天,我們就來(lái)深入探討款功能強(qiáng)大的
    的頭像 發(fā)表于 12-28 15:40 ?549次閱讀

    P82B715:I2C總線擴(kuò)展的得力助手

    P82B715:I2C總線擴(kuò)展的得力助手 在電子設(shè)計(jì)領(lǐng)域,I2C總線一種常用的通信協(xié)議,但它的總線
    的頭像 發(fā)表于 12-26 10:20 ?715次閱讀

    基于FPGA的I2C控制模塊設(shè)計(jì)

    I2C_WRITE_WDATA.v模塊實(shí)現(xiàn)I2C寫(xiě)時(shí)序,I2C_Controller (I2C控制器)例化了
    的頭像 發(fā)表于 12-26 09:48 ?4985次閱讀
    基于FPGA的<b class='flag-5'>I2C</b><b class='flag-5'>控制</b>模塊設(shè)計(jì)

    AS32X601的I2C模塊操作EEPROM詳解

    I2C接口模塊實(shí)現(xiàn)了I2C協(xié)議的標(biāo)準(zhǔn)模式和快速模式,支持多主機(jī)I2C總線架構(gòu)。其標(biāo)準(zhǔn)模式為100K,快速模式400K。而EEPROM,作為一種
    的頭像 發(fā)表于 12-21 21:39 ?986次閱讀
    AS32X601的<b class='flag-5'>I2C</b>模塊操作EEPROM詳解

    I2C總線協(xié)議

    I2C 總線使用兩根信號(hào)線(數(shù)據(jù)線 SDA 和時(shí)鐘線 SCL)在設(shè)備間傳輸數(shù)據(jù)。SCL 為單向時(shí)鐘線,固定由主機(jī)驅(qū)動(dòng)。SDA 為雙向數(shù)據(jù)線,在數(shù)據(jù)傳輸過(guò)程中由收發(fā)兩端分時(shí)驅(qū)動(dòng)。 I2C 總線
    發(fā)表于 12-15 08:07

    I2C死鎖的問(wèn)題

    和SDA信號(hào)變?yōu)楦唠娖健? 這樣,I2C主設(shè)備等待從設(shè)備釋放SDA信號(hào),而同時(shí)I2C從設(shè)備又在等待主設(shè)備將SCL信號(hào)拉低以釋放應(yīng)答信號(hào),兩者相互等待,I2C總線進(jìn)人
    發(fā)表于 12-04 06:00

    I2C的優(yōu)點(diǎn)介紹

    了 PCB(印刷電路板)上的連接器和走線數(shù)量,從而節(jié)省了成本并實(shí)現(xiàn)了緊湊的系統(tǒng)設(shè)計(jì)。 多主多從配置: I2C支持多主多從配置,允許多個(gè)主設(shè)備與同一總線上的多個(gè)從設(shè)備進(jìn)行通信。這種靈活性使得分布式處理架構(gòu)
    發(fā)表于 11-27 07:49

    深入剖析I2C協(xié)議

    ,I2C也是一種可以多主設(shè)備,多從設(shè)備的總線協(xié)議,通過(guò)地址索引,I2C可以使能所需從設(shè)備,I2C的出現(xiàn)主要是用來(lái)實(shí)現(xiàn)不同集成電路組件之間的
    的頭像 發(fā)表于 08-21 15:10 ?3680次閱讀
    深入剖析<b class='flag-5'>I2C</b>協(xié)議

    I2C總線通信,為什么要進(jìn)行電氣隔離?

    I2C總線采用雙向二線制,支持多主機(jī)多從機(jī)通信,具備高可靠性、抗干擾能力強(qiáng),廣泛應(yīng)用于嵌入式系統(tǒng)中。
    的頭像 發(fā)表于 08-11 11:04 ?2513次閱讀
    <b class='flag-5'>I2C</b><b class='flag-5'>總線</b>通信,為什么要進(jìn)行電氣隔離?

    嵌入式學(xué)習(xí)-飛凌嵌入式ElfBoard ELF 1板卡-I2C設(shè)備驅(qū)動(dòng)之Linux下的I2C驅(qū)動(dòng)簡(jiǎn)介

    在Linux下,I2C(Inter-Integrated Circuit)驅(qū)動(dòng)是用于支持I2C總線協(xié)議的驅(qū)動(dòng)程序。I2C一種串行通信協(xié)議,
    發(fā)表于 04-15 10:39

    飛凌嵌入式ElfBoard ELF 1板卡-I2C設(shè)備驅(qū)動(dòng)之Linux下的I2C驅(qū)動(dòng)簡(jiǎn)介

    在Linux下,I2C(Inter-Integrated Circuit)驅(qū)動(dòng)是用于支持I2C總線協(xié)議的驅(qū)動(dòng)程序。I2C一種串行通信協(xié)議,
    發(fā)表于 04-15 10:19

    嵌入式教育科普|I2C接口全面解析

    1、基本概念I2C的全稱(chēng)是Inter-IntegratedCircuit,譯為集成電路總線,是一種同步、雙向、半雙工的兩線式串行接口總線。連接到I2
    的頭像 發(fā)表于 04-11 09:44 ?3252次閱讀
    嵌入式教育科普|<b class='flag-5'>I2C</b>接口全面解析

    是德DSOX4034A示波器I2C總線信號(hào)分析

    在現(xiàn)代電子設(shè)計(jì)與調(diào)試中,I2C(Inter-Integrated Circuit)總線作為一種廣泛應(yīng)用的串行通信協(xié)議,因其簡(jiǎn)單性、靈活性和低功耗特性,成為許多嵌入式系統(tǒng)和電子設(shè)備中不可
    的頭像 發(fā)表于 03-19 13:47 ?1231次閱讀
    是德DSOX4034A示波器<b class='flag-5'>I2C</b><b class='flag-5'>總線</b>信號(hào)分析

    STM32學(xué)習(xí)筆記_I2C詳解(可下載)

    I2C一種簡(jiǎn)單的雙向二線制同步串行總線。它只需要兩根線即可在連接于總線 上的器件之間傳送信息I2C
    發(fā)表于 03-14 17:33 ?3次下載

    I2C總線復(fù)用

    帝晶智慧屏I2C總線復(fù)用
    的頭像 發(fā)表于 03-11 17:20 ?2096次閱讀