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

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

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

記錄一下使用I2C VIP驗(yàn)證芯片的一個(gè)bug

工程師鄧生 ? 來源:小杜的芯片驗(yàn)證日記 ? 作者:小杜 ? 2022-09-21 09:26 ? 次閱讀

最近使用S家的I2C VIP驗(yàn)證芯片的外圍I2C、SMBus總線,作為同樣由SCL和SDA兩根線支撐起的串行總線,協(xié)議相似,因此該I2C VIP也可以配置成SMBus總線使用。只需要更改其最上層的configuration即可,這一點(diǎn)User Guide寫的很清楚,很方便。

具體到SMBus模式的使用場(chǎng)景,我需要在發(fā)送完一筆數(shù)據(jù)后,修改數(shù)據(jù)中的command值,即第一筆數(shù)據(jù)和第二筆數(shù)據(jù)使用的command相同,但需要修改command對(duì)應(yīng)的值。該command在_agent_configuration中聲明,VIP提供了reconfigure_via_task( )來更改該command。

我參考VIP中提供的示例編寫了sequence,其中更改command的代碼如下:

smbus_cfg.master_cfg[0].xxx_cmd = 'hxx;
env.system_env.master[0].reconfigure_via_task(smbus_cfg.master_cfg[0]);

但遇到了問題,數(shù)據(jù)包發(fā)送不完,仿真會(huì)掛死在某個(gè)地方,波形上也會(huì)變成一條直線,但run.log暗示數(shù)據(jù)的確是產(chǎn)生了。隨后,根據(jù)VIP提供的另一個(gè)示例,嘗試在調(diào)用完reconfigure_via_task( )后,通過調(diào)用start( )的方式重新啟動(dòng)sequence,但情況沒有發(fā)生改變。至此,基本定位到了問題出在調(diào)用reconfigure_via_task( )這行代碼上。

重新看run.log,發(fā)現(xiàn)調(diào)用完該task后,VIP的master_agent[0]會(huì)被重新配置成默認(rèn)標(biāo)準(zhǔn)的I2C模式上,這樣問題就合理了,I2C standard模式的確發(fā)不了SMBus fast模式的數(shù)據(jù),這也證實(shí)了run.log中現(xiàn)實(shí)數(shù)據(jù)產(chǎn)生了,但總線上沒有數(shù)據(jù)的情況。

因此,解決的辦法也很簡(jiǎn)單,在調(diào)用reconfigure_via_task( )之前,將SMBus相關(guān)的配置重新配置上即可。


pYYBAGMqaIaAYRnKAAB_NK8th50977.jpg

run.log中藏著debug的信息,在出現(xiàn)bug時(shí)一定要仔細(xì)閱讀run.log,經(jīng)驗(yàn)+1。

這個(gè)問題也和config_db跨層傳參失誤有關(guān),后面再寫~

審核編輯:劉清

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

    關(guān)注

    456

    文章

    51019

    瀏覽量

    425347
  • I2C總線
    +關(guān)注

    關(guān)注

    8

    文章

    391

    瀏覽量

    61054
  • SMBus
    +關(guān)注

    關(guān)注

    1

    文章

    117

    瀏覽量

    22114
  • SCL
    SCL
    +關(guān)注

    關(guān)注

    1

    文章

    239

    瀏覽量

    17115

原文標(biāo)題:日常 - I2C VIP 配置小問題

文章出處:【微信號(hào):小杜的芯片驗(yàn)證日記,微信公眾號(hào):小杜的芯片驗(yàn)證日記】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    I2C總線上拉電阻阻值如何確定?

    導(dǎo)讀I2C總線在產(chǎn)品設(shè)計(jì)中被廣泛應(yīng)用,盡管其結(jié)構(gòu)簡(jiǎn)單,但經(jīng)常發(fā)生上拉電阻設(shè)計(jì)不合理的問題。本文將對(duì)I2C上拉電阻的選擇進(jìn)行簡(jiǎn)要分析。根信號(hào)線上,通過電阻連接
    的頭像 發(fā)表于 12-27 11:34 ?926次閱讀
    <b class='flag-5'>I2C</b>總線上拉電阻阻值如何確定?

    一個(gè)I2C總線,能帶多少片相同的ADS1115芯片?

    請(qǐng)問:同一個(gè)I2C總線,能帶多少片相同的ADS1115芯片,謝謝了?。。∧莻€(gè)地址沒看明白??!怎么操作??
    發(fā)表于 12-27 06:45

    RISC V的I2C操作

    system_i2c_0_io_scl_writeEnable = !system_i2c_0_io_scl_write;Interface配置示例I2C寄存器設(shè)置在I2C的設(shè)置中第
    的頭像 發(fā)表于 11-01 11:06 ?241次閱讀

    I2C協(xié)議的基礎(chǔ)知識(shí)

    本文從I2C協(xié)議的概述開始,描述協(xié)議的歷史、不同速度模式、物理層和數(shù)據(jù)幀結(jié)構(gòu),最后介紹I2C混合電壓系統(tǒng)中電平兼容性以及上拉電阻大小計(jì)算。
    的頭像 發(fā)表于 10-22 15:51 ?604次閱讀
    <b class='flag-5'>I2C</b>協(xié)議的基礎(chǔ)知識(shí)

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

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

    了解I2C總線

    電子發(fā)燒友網(wǎng)站提供《了解I2C總線.pdf》資料免費(fèi)下載
    發(fā)表于 10-08 11:13 ?2次下載
    了解<b class='flag-5'>I2C</b>總線

    I2C基本指南

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

    CAN轉(zhuǎn)I2C橋接器

    電子發(fā)燒友網(wǎng)站提供《CAN轉(zhuǎn)I2C橋接器.pdf》資料免費(fèi)下載
    發(fā)表于 08-28 11:10 ?0次下載
    CAN轉(zhuǎn)<b class='flag-5'>I2C</b>橋接器

    簡(jiǎn)單認(rèn)識(shí)I2C通信協(xié)議

    I2C(Inter-Integrated Circuit)通信協(xié)議是由飛利浦公司(現(xiàn)為恩智浦半導(dǎo)體)開發(fā)的種簡(jiǎn)單、雙向二線制同步串行總線協(xié)議。自1982年發(fā)布以來,I2C協(xié)議因其高效、靈活和易于實(shí)現(xiàn)的特點(diǎn),在電子設(shè)備間的數(shù)據(jù)交
    的頭像 發(fā)表于 07-25 18:06 ?1586次閱讀

    INA226 i2c讀取時(shí)顯示不支持I2C總線操作怎么解決?

    目前在調(diào)試款I(lǐng)NA226電壓檢測(cè)芯片,已經(jīng)連接成功能正常讀到設(shè)備的芯片ID驗(yàn)證是對(duì)的, 但是我在循環(huán)里延時(shí)秒去讀電壓的時(shí)候出現(xiàn)了讀錯(cuò)誤
    發(fā)表于 07-09 06:37

    I2C接口+高度集成的電源管理芯片PMIC-iML1942

    電源管理芯片 - iML1942是個(gè)高度集成的電源管理IC為TFT液晶面板。它具有完整的I2C接口來編程各種參數(shù)。
    的頭像 發(fā)表于 07-05 09:27 ?719次閱讀
    <b class='flag-5'>I2C</b>接口+高度集成的電源管理<b class='flag-5'>芯片</b>PMIC-iML1942

    I2C邏輯選型指南

    電子發(fā)燒友網(wǎng)站提供《I2C邏輯選型指南.pdf》資料免費(fèi)下載
    發(fā)表于 06-20 16:20 ?2次下載

    SPI和I2C通信協(xié)議:應(yīng)用與區(qū)別

    本文深入解析了SPI和I2C這兩種通信協(xié)議的特點(diǎn)、工作原理和應(yīng)用場(chǎng)景。SPI適用于高速數(shù)據(jù)傳輸,常用于存儲(chǔ)器芯片和顯示器驅(qū)動(dòng)等領(lǐng)域;I2C適用于低速控制和傳感器數(shù)據(jù)傳輸,常用于溫度傳感器和ADC
    的頭像 發(fā)表于 04-22 16:45 ?1908次閱讀

    什么是I2C協(xié)議 I2C總線的控制邏輯

    在實(shí)際使用過程中,I2C比較容易出現(xiàn)的個(gè)問題就是死鎖 ,死鎖在I2C中主要表現(xiàn)為:I2C死鎖時(shí)表現(xiàn)為SCL為高,SDA
    發(fā)表于 03-12 09:17 ?1130次閱讀
    什么是<b class='flag-5'>I2C</b>協(xié)議 <b class='flag-5'>I2C</b>總線的控制邏輯

    GD32 MCU硬件I2C不可靠不如軟件I2C?來看看紅楓派開發(fā)版的硬件I2C驅(qū)動(dòng)如何做到穩(wěn)得

    個(gè)評(píng)論中,看到網(wǎng)友對(duì)硬件I2C的討論,硬件I2C Busy找不到原因、軟件I2C穩(wěn)得批。
    的頭像 發(fā)表于 02-23 09:37 ?2848次閱讀
    GD32 MCU硬件<b class='flag-5'>I2C</b>不可靠不如軟件<b class='flag-5'>I2C</b>?來看看紅楓派開發(fā)版的硬件<b class='flag-5'>I2C</b>驅(qū)動(dòng)如何做到穩(wěn)得<b class='flag-5'>一</b>批