在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

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

先楫半導體HPMicro ? 2023-07-11 10:01 ? 次閱讀

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

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

1

I2C 特征

支持標準模式 (100Kb/s),快速模式 (400Kb/s) 和快速模式 +(1Mb/s)

可配置主從模式

支持 7 位和 10 位地址模式

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

自動時鐘延展 (clock stretching)

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

支持直接內存訪問 (DMA)

4 字節(jié) FIFO

2

I2C 功能

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


4個字節(jié)FIFO,可不使用DMA的情況下,滿足多字節(jié)一次性傳輸。并且軟件沒有準備好下一個字節(jié)的收發(fā)數(shù)據(jù)或者FIFO已滿時候,I2C控制器會自動延展I2C總線時鐘來暫停總線傳輸。


I2C控制器默認使能了自動ACK響應,即是除了最后一個字節(jié)外其余字節(jié)接收后都會自動發(fā)出ACK,軟件可以使能字節(jié)接收中斷來禁止自動響應功能,軟件自己接收后決定是否發(fā)送ACK。

3

場合需求

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


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

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

傳輸過程中需要restart重新發(fā)送start信號

舉例,比如SMBUS,在進行block read傳輸中,就需要傳輸過程中發(fā)送restart信號,并且切換讀寫方向。

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

4

實現(xiàn)方式

先楫半導體的用戶手冊對于 I2C 的寄存器說明一共有好幾個,本文重點介紹以下三個密切相關的寄存器:

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

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

2. INTEN寄存器的BYTERECV位,開啟或關閉自動響應功能。

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

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

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

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

/**

* @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;

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

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

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

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

5

驗證功能

根據(jù)以上信息,我們來操作一個實驗,以sdk的poll例子的master和slave兩個開發(fā)板進行相互收發(fā),slave不做改動,master的讀寫接口替換以上的接口。

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;

}

實驗現(xiàn)象

①當把一次完整傳輸拆分三次frame傳輸時候,依舊是沒什么問題的??梢娨陨系墓δ苁褂貌]有什么問題。

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

② 可以模擬下一個配置錯誤的現(xiàn)象,開啟auto-ack功能,master接收slave數(shù)據(jù)的數(shù)據(jù),由于開啟了自動響應,在第一包frame接收的時候,I2C控制器認為傳輸?shù)阶詈笠粋€字節(jié),會自動補充NACK,但我們并不希望補充NACK,因為一次完整的傳輸還沒完成,這時候就需要軟件自己添加ACK或者NACK。

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

6

小 結

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

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

    關注

    10

    文章

    2938

    瀏覽量

    89196
  • I2C
    I2C
    +關注

    關注

    28

    文章

    1522

    瀏覽量

    126665
收藏 人收藏

    評論

    相關推薦
    熱點推薦

    I2C總線復用

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

    I2C總線通信原理 如何設計I2C總線電路

    I2C總線通信原理 I2C(Inter-Integrated Circuit)總線一種用于集成電路之間進行通信的串行通信協(xié)議。它最早由飛利
    的頭像 發(fā)表于 01-31 15:01 ?739次閱讀

    基于I2C總線的智能家居應用

    隨著科技的飛速發(fā)展,智能家居系統(tǒng)已經(jīng)成為現(xiàn)代生活的個重要組成部分。I2C(Inter-Integrated Circuit)總線一種串行通信協(xié)議,廣泛應用于微
    的頭像 發(fā)表于 01-17 16:21 ?406次閱讀

    I2C總線的優(yōu)缺點分析

    I2C總線作為一種廣泛使用的串行通信協(xié)議,以其簡單性和高效性在嵌入式系統(tǒng)中占據(jù)著重要地位。 I2C總線的優(yōu)點 1. 簡單性和低成本
    的頭像 發(fā)表于 01-17 15:50 ?739次閱讀

    I2C總線與Arduino的接口示例

    在現(xiàn)代電子設計中,I2C總線因其簡單性和靈活性而廣受歡迎。它允許多個設備共享同通信線路,從而節(jié)省空間和成本。Arduino,作為個多功能
    的頭像 發(fā)表于 01-17 15:34 ?1156次閱讀

    I2C總線的工作模式介紹

    在現(xiàn)代電子系統(tǒng)中,I2C總線作為一種多主機、多從機的串行通信協(xié)議,扮演著至關重要的角色。它允許多個設備共享同一總線,進行數(shù)據(jù)傳輸,從而簡化了系統(tǒng)設計并降低了成本。
    的頭像 發(fā)表于 01-17 15:32 ?645次閱讀

    I2C總線協(xié)議詳細解析

    1. I2C總線簡介 I2C總線由Philips Semiconductor(現(xiàn)為NXP Semiconductors)在1980年代初期開發(fā)。它是
    的頭像 發(fā)表于 01-17 15:22 ?623次閱讀

    I2C總線故障排除技巧

    I2C總線一種廣泛使用的串行通信協(xié)議,它允許多個設備在兩條線上(數(shù)據(jù)線SDA和時鐘線SCL)進行通信。由于其簡單性和靈活性,I2C
    的頭像 發(fā)表于 01-17 15:20 ?1641次閱讀

    I2C總線與單片機的連接

    在現(xiàn)代電子系統(tǒng)中,單片機(MCU)是核心控制單元,而I2C總線作為一種多主機、多從機的串行通信協(xié)議,因其簡單、高效和節(jié)省引腳的特性而被廣泛應用于各種電子設備中。
    的頭像 發(fā)表于 01-17 15:18 ?778次閱讀

    I2C總線設備地址設置方法

    I2C總線一種廣泛使用的串行通信協(xié)議,它允許多個設備在兩條線上(數(shù)據(jù)線SDA和時鐘線SCL)進行通信。每個設備都有個唯的地址,以確保數(shù)
    的頭像 發(fā)表于 01-17 15:17 ?2775次閱讀

    I2C總線數(shù)據(jù)傳輸速度要求

    I2C(Inter-Integrated Circuit)總線一種同步的、多主機、多從機的串行計算機總線,用于連接微控制器和其他設備。它由
    的頭像 發(fā)表于 01-17 15:15 ?1456次閱讀

    I2C總線應用實例分析

    在現(xiàn)代電子系統(tǒng)中,I2C總線因其簡單、靈活和高效的特點而被廣泛應用于各種設備之間的通信。 I2C總線概述
    的頭像 發(fā)表于 01-17 15:09 ?516次閱讀

    I2C總線與SPI總線的比較

    在現(xiàn)代電子系統(tǒng)中,微控制器與各種外設之間的通信是必不可少的。I2C和SPI是兩流行的串行通信協(xié)議,它們各自具有獨特的特點和應用場景。 I2C總線
    的頭像 發(fā)表于 01-17 15:08 ?666次閱讀

    詳解I2C總線與SPI總線的區(qū)別

    I2C(Inter-Integrated Circuit)表示集成電路互連,是一種用于線路板內部芯片之間通信的總線。
    的頭像 發(fā)表于 10-16 15:16 ?1.3w次閱讀
    詳解<b class='flag-5'>I2C</b><b class='flag-5'>總線</b>與SPI<b class='flag-5'>總線</b>的區(qū)別

    I2C總線協(xié)議的工作原理和尋址格式

    I2C(Inter-Integrated Circuit)總線協(xié)議,即集成電路總線協(xié)議,是一種用于連接微控制器及其外圍設備的串行
    的頭像 發(fā)表于 05-27 15:47 ?2465次閱讀
    主站蜘蛛池模板: 四虎国产欧美成人影院 | 婷婷婷色 | 激情5月婷婷 | 色多多免费视频观看区一区 | 免费欧美黄色 | 手机看片日韩永久福利盒子 | 一级片黄色免费 | 艹逼视频免费 | 日本特黄色大片 | 俺去久久| 好大好猛好爽好深视频免费 | 丁香花在线| 五月激情网站 | 亚洲国产福利精品一区二区 | 夜夜视频| 亚洲第一页国产 | 大尺度很肉污的古代小说 | 欧美成人xxxx| 免费久久久久 | 夜夜干天天操 | 欧美色欧美亚洲高清在线观看 | h色小视频 | 女bbbbxxxx毛片视频丶 | 久久精品午夜 | 天天射天天射天天射 | 天天干网址 | 日本网站免费 | 久操操| 亚洲色图久久 | 国产精品国产三级国产普通话对白 | 九九精品影院 | 一道精品视频一区二区三区男同 | 天天综合天天看夜夜添狠狠玩 | 色爽视频| 天天综合天天看夜夜添狠狠玩 | 欧美黑粗 | 国产精品亚洲一区二区三区在线播放 | 男女视频在线看 | 国产福利不卡一区二区三区 | 2021国产成人精品久久 | 日本动漫在线看 |