国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

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

3天內不再提示

RISC V的I2C操作

XL FPGA技術交流 ? 2024-11-01 11:06 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群


接口處理

top接口

output system_i2c_0_io_sda_writeEnable,

output system_i2c_0_io_sda_write,

input system_i2c_0_io_sda_read,

output system_i2c_0_io_scl_writeEnable,

output system_i2c_0_io_scl_write,

input system_i2c_0_io_scl_read,

soc接口處理

.system_i2c_0_io_sda_write(system_i2c_0_io_sda_write),

.system_i2c_0_io_sda_read(system_i2c_0_io_sda_read),

.system_i2c_0_io_scl_write(system_i2c_0_io_scl_write),

.system_i2c_0_io_scl_read(system_i2c_0_io_scl_read),

WriteEnable信號的處理

I2CSDASCL對應FPGA雙向IO,需設置為弱上拉。

I2C對應的三態門的OE信號:需要賦值為I2C SDA/SCLwrite信號;rtl中的表述如下:

主要原因在于:i2c通信過程中,當總線空閑時,兩根線均為高電平。連到總線上的任一器件輸出的低電平,都將使總線的信號變低,即各器件的SDASCL都是線""關系。

2)引腳在輸出信號的同時還將引腳上的電平進行檢測,檢測是否與剛才輸出一致,為"時鐘同步""總線仲裁"提供了硬件基礎。

assign system_i2c_0_io_sda_writeEnable = !system_i2c_0_io_sda_write;

assign system_i2c_0_io_scl_writeEnable = !system_i2c_0_io_scl_write;

Interface配置示例


I2C寄存器設置

在I2C的設置中第一步是要配置寄存器。寄存器的說明在ds文檔中。

tsuData中,1代表10ns;

Timeout中,1表示10ns

tLow和tHigh的1代表10ns




10.1.3 軟件部分(Risc V

l I2C通信主要包括以下幾個部分:

1、主設備發送起始位(Start

2、主/從發送數據(TxData(注:軟件處理時,主發送從設備的地址和讀/寫位,與發送數據處理方式相同)

3、主/從接收數據(RxData

4、主/從發送應答信號(ACK

5、主設備發送停止位(Stop


l 對應的C函數:

1、主設備發送起始位(Start

i2c_masterStartBlocking(I2C_CTRL);//master send start signal

2、主/從發送數據(TxData

i2c_txByte(I2C_CTRL, 0xC0);//master/slave send data

3、/從接收數據(RxData

i2c_rxData(I2C_CTRL)//master/slave receive data

4、主/從發送應答信號(ACK

i2c_txAckBlocking(I2C_CTRL);//master/slave send ACKi2c_txNackBlocking(I2C_CTRL);//master/slave send NaCK#(不需要發送ACK,但是需要等待一個應答周期的時候,用Nack函數)

5、主設備發送停止位(Stop

i2c_masterStopBlocking(I2C_CTRL);//master send stop

l 小結:

RISC V中提供的關于I2C的函數,相當于把I2C通信過程中各個狀態進行了分解的,上述提到的各個函數功能,除了必須通過I2C主設備實現的功能:發送startstop之外,函數本身并沒有主從之分;

當需要RISC V中的I2C做從設備時,只需監控總線狀態(如是否接收到有效的數據等),同時調用對應的函數,給主設備發送應答信號,根據主設備提供的指令,接收/發送相應的數據即可;

硬件驗證平臺


原文標題:RISC V的I2C操作

文章出處:【微信公眾號:易靈思FPGA技術交流】歡迎添加關注!文章轉載請注明出處。

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

    關注

    1660

    文章

    22412

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    I2C 為什么只要兩根線就能搞定通信?

    到目前為止,我們已經討論了SPI通信和UART通信的基礎知識,現在讓我們討論本系列的最后一個協議,即集成電路間協議(I2C)。如果您曾經構建過使用OLED顯示器、氣壓傳感器或陀螺儀/加速度計模塊
    的頭像 發表于 01-04 09:14 ?1646次閱讀
    <b class='flag-5'>I2C</b> 為什么只要兩根線就能搞定通信?

    P82B715:I2C總線擴展的得力助手

    )的P82B715,一款專門用于緩沖高電容I2C總線系統的器件,看看它是如何解決這些問題的。 文件下載: p82b715.pdf 1. 器件概述 P82B715是一款支持通過I2C總線進行雙向數據傳輸的器件,它能夠緩沖
    的頭像 發表于 12-26 10:20 ?710次閱讀

    基于FPGA的I2C控制模塊設計

    I2C_WRITE_WDATA.v模塊實現I2C寫時序,I2C_Controller (I2C控制器)例化了I2C_WRITE_WDATA.v
    的頭像 發表于 12-26 09:48 ?4971次閱讀
    基于FPGA的<b class='flag-5'>I2C</b>控制模塊設計

    探索TCA1116:低電壓16位I2C I/O擴展器的卓越性能

    時,SDA和SCL仍具有5V容限(泄漏電流1uA),這為電源管理提供了更大的靈活性。同時,它支持1.8VI2C操作,能適應不同的電源
    的頭像 發表于 12-24 09:55 ?710次閱讀

    AS32X601的I2C模塊操作EEPROM詳解

    國科安芯推出的AS32X601系列MCU芯片內置的I2C模塊提供了符合工業標準的兩線串行制接口,可用于MCU和外部I2C設備的通訊。I2C總線使用兩條串行線:串行數據線SDA和串行時鐘線SCL
    的頭像 發表于 12-21 21:39 ?984次閱讀
    AS32X601的<b class='flag-5'>I2C</b>模塊<b class='flag-5'>操作</b>EEPROM詳解

    TCAL6408:8位轉換I2C總線/SMBus I/O擴展器的深度剖析

    1.08V至3.6V,支持1.2V、1.8V、2.5V和3.3V
    的頭像 發表于 12-16 11:45 ?1141次閱讀

    TCAL6416R:16位轉換I2C總線、SMBus I/O擴展器的深度解析

    TCAL6416R的工作電源電壓范圍為1.08V至3.6V,無論是I2C總線側(VCCI)還是P端口側(VCCP)都能適應這一寬電壓范圍。它支持1.2V、1.8
    的頭像 發表于 12-15 17:55 ?2225次閱讀

    I2C死鎖的問題

    在實際使用過程中,I2C比較容易出現的一個問題就是死鎖 ,死鎖在I2C中主要表現為:I2C死鎖時表現為SCL為高,SDA一直為低。 在I2C主設備進行讀寫
    發表于 12-04 06:00

    深入剖析I2C協議

    I2C是由Philips開發的簡單的雙向兩線總線,在深入淺出理解SPI協議中,我們區分了單工,半雙工,全雙工協議數據流向的區別,根據特征,I2C協議屬于半雙工協議(即同一時刻,數據單向流動)。此外
    的頭像 發表于 08-21 15:10 ?3675次閱讀
    深入剖析<b class='flag-5'>I2C</b>協議

    第十八章 I2C通信測試

    本章介紹了I2C協議,其物理層用SDA和SCL雙線,支持多設備:協議層含起始/停止信號、應答機制等。還講解W55MH32的I2C外設及初始化,并進行了通信測試代碼的分析。
    的頭像 發表于 06-19 17:07 ?1314次閱讀
    第十八章 <b class='flag-5'>I2C</b>通信測試

    CYPD3177 I2C通信無應答怎么解決?

    SOC端通過I2C與CYPD3177進行通信,在讀芯片ID時(0x0002寄存器),主機發送數據后無應答。目前SOC端和CYPD3177只連接了兩根I2C線,一根地線和3.3V供電。硬件連接是否有問題?軟件配置在讀ID前是否需要
    發表于 05-12 07:10

    簡單了解I2C接口

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

    基于RT-Thread的I2C(軟件) 實踐 | 技術集結

    一、軟硬件介紹(一)I2C(軟件)I2C是一種廣泛應用于嵌入式系統中的短距離串行通信協議,支持多主多從設備模式,主機通過時鐘信號SCL和數據線SDA與從機進行數據交互。在RT-Thread操作系統中
    的頭像 發表于 05-06 18:44 ?1047次閱讀
    基于RT-Thread的<b class='flag-5'>I2C</b>(軟件) 實踐 | 技術集結

    是德DSOX4034A示波器I2C總線信號分析

    在現代電子設計與調試中,I2C(Inter-Integrated Circuit)總線作為一種廣泛應用的串行通信協議,因其簡單性、靈活性和低功耗特性,成為許多嵌入式系統和電子設備中不可或缺的通信方式
    的頭像 發表于 03-19 13:47 ?1227次閱讀
    是德DSOX4034A示波器<b class='flag-5'>I2C</b>總線信號分析

    I2C總線復用

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