一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

AS32系列MCU芯片I2C模塊性能解析與調(diào)試

安芯 ? 來(lái)源:jf_29981791 ? 作者:jf_29981791 ? 2025-06-20 16:31 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

國(guó)科安芯推出的AS32X601內(nèi)置的I2C模塊提供了符合工業(yè)標(biāo)準(zhǔn)的兩線(xiàn)串行制接口,可用于MCU和外部IIC設(shè)備的通訊。IIC總線(xiàn)使用兩條串行線(xiàn):串行數(shù)據(jù)線(xiàn)SDA和串行時(shí)鐘線(xiàn)SCL。 IIC接口模塊實(shí)現(xiàn)了IIC協(xié)議的標(biāo)準(zhǔn)模式和快速模式,支持多主機(jī)IIC總線(xiàn)架構(gòu)。其中標(biāo)準(zhǔn)模式為100K,快速模式400K。

  • 硬件設(shè)計(jì)

I2C 總線(xiàn)內(nèi)部使用漏極開(kāi)路輸出驅(qū)動(dòng)器,因此 SDA和 SCL 可以被拉低為低電平,但是不能被驅(qū)動(dòng)為高電平,所以每條線(xiàn)上都要使用一個(gè)4.7K上拉電阻,默認(rèn)情況下將其保持在高電平。

  • I2C時(shí)序

①Start開(kāi)始信號(hào)、Stop停止信號(hào):

這兩個(gè)信號(hào)由主機(jī)產(chǎn)生,不屬于數(shù)據(jù)域交互:

在SCL的高電平時(shí),主機(jī)將SDA的電平由 高–>低是Start信號(hào)(下降沿);

在SCL的高電平時(shí),主機(jī)將SDA的電平由 低–>高是Stop信號(hào)(上升沿);

②7位尋址

AS32X601的I2C只支持7位尋址模式,配置過(guò)程中從機(jī)地址需要左移1位才為實(shí)際地址。

③數(shù)據(jù)方向

0寫(xiě)/1讀

④應(yīng)答ACK、非應(yīng)答NACK

在SCL的一個(gè)時(shí)鐘周期內(nèi),從機(jī)在SCL的高電平時(shí),將SDA的電平由高拉低(或者繼續(xù)保持低電平狀態(tài)) 則是ACK信號(hào);

從機(jī)在SCL的高電平時(shí),如果SDA的電平一直是 高電平 則是NACK信號(hào);

  • 時(shí)鐘

I2C0、I2C1時(shí)鐘來(lái)自APB0,I2C2、I2C3時(shí)鐘來(lái)自ABP1。具體配置可見(jiàn)I2C_CTLR寄存器。

  1. 配置I2Cx需要的GPIO為復(fù)用功能。
  2. 通過(guò)配置I2C_INITSTRUCT初始化I2Cx,包括時(shí)鐘分頻,從機(jī)地址,ACK,高低電平時(shí)間等。

  1. 按需求配置中斷,并配置IRQ_HANDLER;
  2. 調(diào)用收發(fā)接口,并處理數(shù)據(jù)
  • I2C掛死原因解析

由于I2C采用線(xiàn)與結(jié)構(gòu),只要總線(xiàn)上任何一個(gè)器件拉低了SDA或者SCL,其他器件都無(wú)法拉高它們,看到的都是低電平。如果有器件不釋放總線(xiàn),則整個(gè)總線(xiàn)上的通訊都會(huì)被暫停 。

在實(shí)際操作中,I2C主是可編程器件,如果主機(jī)主動(dòng)拉低了總線(xiàn),可以通過(guò)調(diào)試代碼了解原因,也可以通過(guò)復(fù)位I2C外設(shè)或者復(fù)位芯片來(lái)退出。而I2C從機(jī)往往不帶RESET引腳,如果掛死了總線(xiàn)即使整個(gè)系統(tǒng)復(fù)位都無(wú)法解除,僅重新上下電才可以恢復(fù),因此分析I2C從機(jī)掛死。

首先I2C從機(jī)在兩種情況下會(huì)拉低SDA線(xiàn)。

①主機(jī)向從機(jī)寫(xiě)數(shù)據(jù)或地址時(shí),從機(jī)如果發(fā)出ACK應(yīng)答,則會(huì)第9個(gè)CLK的期間拉低SDA;

②主機(jī)讀數(shù)據(jù)的時(shí)候,從機(jī)會(huì)在bit為0時(shí)對(duì)應(yīng)的CLK期間拉低SDA。

根據(jù)I2C協(xié)議,SCL為高的時(shí)候,SDA電平應(yīng)保持,而等到SCL為低后(也就是下降沿后)才能發(fā)生改變。若SCL拉高后主機(jī)不再拉低,從機(jī)會(huì)持續(xù)拉低SDA,直到見(jiàn)到SDA的下降沿。

最常見(jiàn)的情況是主機(jī)在通訊的過(guò)程中產(chǎn)生了復(fù)位。由于復(fù)位動(dòng)作通常會(huì)立刻執(zhí)行,外設(shè)狀態(tài)機(jī)都恢復(fù)到默認(rèn)狀態(tài),也就發(fā)不出完整的CLK。那么等到主機(jī)復(fù)位完成回來(lái)后,SCL為高,SDA被從機(jī)拉低。主機(jī)無(wú)法發(fā)起START起始條件,不能開(kāi)始下一次與從機(jī)的通訊,這稱(chēng)為SDA掛死。

我們一般情況下用GPIO在SCL線(xiàn)上模擬一個(gè)下降沿,讓從機(jī)狀態(tài)機(jī)繼續(xù)走下去。只發(fā)一個(gè)下降沿并不一定能將SDA釋放,因?yàn)椴⒉磺宄?dāng)主機(jī)復(fù)位異常發(fā)生時(shí)刻從機(jī)到底處于哪一個(gè)狀態(tài),所以需要逐個(gè)CLOCK去抓波形,直到見(jiàn)到SDA被釋放了,我們才終止并且發(fā)送STOP條件告訴從機(jī)這次通訊結(jié)束。

審核編輯 黃宇

聲明:本文內(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)注

    459

    文章

    52352

    瀏覽量

    438539
  • mcu
    mcu
    +關(guān)注

    關(guān)注

    146

    文章

    17915

    瀏覽量

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

    關(guān)注

    28

    文章

    1538

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    AS32系列MCU調(diào)試教程 SPI調(diào)試的常見(jiàn)問(wèn)題解析

    簡(jiǎn)介 AS32X601內(nèi)置的I2C模塊提供了支持全雙工的同步串行通信。該接口可配置為主機(jī)或從機(jī)模式,配置為主機(jī)模式時(shí),它可為外部從器件提供通信時(shí)鐘(SCK),6個(gè)SPI每個(gè)都支持8個(gè)從機(jī)。 SPI
    的頭像 發(fā)表于 06-27 18:10 ?57次閱讀
    <b class='flag-5'>AS32</b><b class='flag-5'>系列</b><b class='flag-5'>MCU</b><b class='flag-5'>調(diào)試</b>教程 SPI<b class='flag-5'>調(diào)試</b>的常見(jiàn)問(wèn)題<b class='flag-5'>解析</b>

    簡(jiǎn)單了解I2C接口

    在電子電路的復(fù)雜世界里,各種電路模塊設(shè)備需要相互通信才能協(xié)同工作 ,I2C接口就像是電路模塊設(shè)備間的溝通橋梁,今天就帶大家深入了解它。
    的頭像 發(fā)表于 05-08 14:15 ?722次閱讀
    簡(jiǎn)單了解<b class='flag-5'>I2C</b>接口

    I2C總線(xiàn)復(fù)用

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

    I2C總線(xiàn)協(xié)議詳細(xì)解析

    1. I2C總線(xiàn)簡(jiǎn)介 I2C總線(xiàn)由Philips Semiconductor(現(xiàn)為NXP Semiconductors)在1980年代初期開(kāi)發(fā)。它是一種多主機(jī)總線(xiàn),允許多個(gè)設(shè)備共享同一總線(xiàn)。I2C
    的頭像 發(fā)表于 01-17 15:22 ?832次閱讀

    I2C總線(xiàn)應(yīng)用實(shí)例分析

    在現(xiàn)代電子系統(tǒng)中,I2C總線(xiàn)因其簡(jiǎn)單、靈活和高效的特點(diǎn)而被廣泛應(yīng)用于各種設(shè)備之間的通信。 I2C總線(xiàn)概述 I2C總線(xiàn)由Philips(現(xiàn)為NXP)在1980年代初期開(kāi)發(fā),最初用于音頻和視頻設(shè)備
    的頭像 發(fā)表于 01-17 15:09 ?691次閱讀

    AN-806: ADuC70xxBCPZxxI系列芯片I2C下載協(xié)議

    電子發(fā)燒友網(wǎng)站提供《AN-806: ADuC70xxBCPZxxI系列芯片I2C下載協(xié)議.pdf》資料免費(fèi)下載
    發(fā)表于 01-15 16:18 ?0次下載
    AN-806: ADuC70xxBCPZxxI<b class='flag-5'>系列</b><b class='flag-5'>芯片</b><b class='flag-5'>I2C</b>下載協(xié)議

    TMS320C6000 DSP內(nèi)部集成電路(I2C)模塊參考指南

    電子發(fā)燒友網(wǎng)站提供《TMS320C6000 DSP內(nèi)部集成電路(I2C)模塊參考指南.pdf》資料免費(fèi)下載
    發(fā)表于 12-30 16:43 ?0次下載
    TMS320<b class='flag-5'>C</b>6000 DSP內(nèi)部集成電路(<b class='flag-5'>I2C</b>)<b class='flag-5'>模塊</b>參考指南

    使用MSP430 MCU通過(guò)I2C實(shí)現(xiàn)低功耗Windows 8 HID應(yīng)用

    電子發(fā)燒友網(wǎng)站提供《使用MSP430 MCU通過(guò)I2C實(shí)現(xiàn)低功耗Windows 8 HID應(yīng)用.pdf》資料免費(fèi)下載
    發(fā)表于 10-17 09:19 ?0次下載
    使用MSP430 <b class='flag-5'>MCU</b>通過(guò)<b class='flag-5'>I2C</b>實(shí)現(xiàn)低功耗Windows 8 HID應(yīng)用

    在低成本MSP430 MCU中集成I2C I/O擴(kuò)展器

    電子發(fā)燒友網(wǎng)站提供《在低成本MSP430 MCU中集成I2C I/O擴(kuò)展器.pdf》資料免費(fèi)下載
    發(fā)表于 09-24 10:56 ?0次下載
    在低成本MSP430 <b class='flag-5'>MCU</b>中集成<b class='flag-5'>I2C</b> <b class='flag-5'>I</b>/O擴(kuò)展器

    使用MSP430 MCU簡(jiǎn)化溫度、濕度和光學(xué)I2C傳感器

    電子發(fā)燒友網(wǎng)站提供《使用MSP430 MCU簡(jiǎn)化溫度、濕度和光學(xué)I2C傳感器.pdf》資料免費(fèi)下載
    發(fā)表于 09-14 11:03 ?0次下載
    使用MSP430 <b class='flag-5'>MCU</b>簡(jiǎn)化溫度、濕度和光學(xué)<b class='flag-5'>I2C</b>傳感器

    使用低內(nèi)存MSP430?MCU的UART到I2C橋應(yīng)用說(shuō)明

    電子發(fā)燒友網(wǎng)站提供《使用低內(nèi)存MSP430?MCU的UART到I2C橋應(yīng)用說(shuō)明.pdf》資料免費(fèi)下載
    發(fā)表于 09-14 10:45 ?0次下載
    使用低內(nèi)存MSP430?<b class='flag-5'>MCU</b>的UART到<b class='flag-5'>I2C</b>橋應(yīng)用說(shuō)明

    I2C基本指南

    電子發(fā)燒友網(wǎng)站提供《I2C基本指南.pdf》資料免費(fèi)下載
    發(fā)表于 09-10 09:40 ?0次下載
    <b class='flag-5'>I2C</b>基本指南

    如何調(diào)試I2C

    電子發(fā)燒友網(wǎng)站提供《如何調(diào)試I2C.pdf》資料免費(fèi)下載
    發(fā)表于 08-27 10:38 ?0次下載
    如何<b class='flag-5'>調(diào)試</b><b class='flag-5'>I2C</b>

    使用C2000 I2C模塊連接EEPROM

    電子發(fā)燒友網(wǎng)站提供《使用C2000 I2C模塊連接EEPROM.pdf》資料免費(fèi)下載
    發(fā)表于 08-27 09:53 ?0次下載
    使用<b class='flag-5'>C</b>2000 <b class='flag-5'>I2C</b><b class='flag-5'>模塊</b>連接EEPROM

    【GD32 MCU 入門(mén)教程】GD32 MCU 常見(jiàn)外設(shè)介紹(7)I2C 模塊介紹

    ,連接各種集成 電路和功能模塊。I2C器件能夠減少電路間的連接,減少電路板的尺寸,降低硬件成本并提高系統(tǒng)的可靠性。
    的頭像 發(fā)表于 08-16 09:54 ?1313次閱讀
    【GD32 <b class='flag-5'>MCU</b> 入門(mén)教程】GD32 <b class='flag-5'>MCU</b> 常見(jiàn)外設(shè)介紹(7)<b class='flag-5'>I2C</b> <b class='flag-5'>模塊</b>介紹