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

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

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

fireflyAIO-3399J主板I2C使用介紹

firefly ? 來源:firefly ? 作者:firefly ? 2019-12-24 10:34 ? 次閱讀

I2C 使用

簡介

AIO-3399J 開發(fā)板上有 9 個(gè)片上 I2C 控制器,各個(gè) I2C 的使用情況如下表:

本文主要描述如何在該開發(fā)板上配置 I2C。

配置 I2C 可分為兩大步驟:

定義和注冊 I2C 設(shè)備

定義和注冊 I2C 驅(qū)動

下面以配置 GSL3680 為例。

定義和注冊 I2C 設(shè)備

在注冊I2C設(shè)備時(shí),需要結(jié)構(gòu)體 i2c_client 來描述 I2C 設(shè)備。然而在標(biāo)準(zhǔn)Linux中,用戶只需要提供相應(yīng)的 I2C 設(shè)備信息,Linux就會根據(jù)所提供的信息構(gòu)造 i2c_client 結(jié)構(gòu)體。

用戶所提供的 I2C 設(shè)備信息以節(jié)點(diǎn)的形式寫到 dts 文件中,如下所示:

kernel/arch/arm64/boot/dts/rockchip/rk3399-firefly-mini-edp.dts &i2c4 { status = "okay"; gsl3680: gsl3680@41 { compatible = "gslX680"; reg = <0x41>; screen_max_x = <1536>; screen_max_y = <2048>; touch-gpio = <&gpio1 20 IRQ_TYPE_LEVEL_LOW>; reset-gpio = <&gpio0 12 GPIO_ACTIVE_HIGH>; }; };

定義和注冊 I2C 驅(qū)動

定義 I2C 驅(qū)動

在定義 I2C 驅(qū)動之前,用戶首先要定義變量 of_device_id 和 i2c_device_id 。

of_device_id 用于在驅(qū)動中調(diào)用dts文件中定義的設(shè)備信息,其定義如下所示:

static struct of_device_id gsl_ts_ids[] = { {.compatible = "gslX680"}, {} };

定義變量 i2c_device_id:

static const struct i2c_device_id gsl_ts_id[] = { {GSLX680_I2C_NAME, 0}, {} }; MODULE_DEVICE_TABLE(i2c, gsl_ts_id);

i2c_driver 如下所示:

static struct i2c_driver gsl_ts_driver = { .driver = { .name = GSLX680_I2C_NAME, .owner = THIS_MODULE, .of_match_table = of_match_ptr(gsl_ts_ids), }, #ifndef CONFIG_HAS_EARLYSUSPEND //.suspend = gsl_ts_suspend, //.resume = gsl_ts_resume, #endif .probe = gsl_ts_probe, .remove = gsl_ts_remove, .id_table = gsl_ts_id, };

注:變量id_table指示該驅(qū)動所支持的設(shè)備。

注冊 I2C 驅(qū)動

使用i2c_add_driver函數(shù)注冊 I2C 驅(qū)動。

i2c_add_driver(&gsl_ts_driver);

在調(diào)用 i2c_add_driver 注冊 I2C 驅(qū)動時(shí),會遍歷 I2C 設(shè)備,如果該驅(qū)動支持所遍歷到的設(shè)備,則會調(diào)用該驅(qū)動的 probe 函數(shù)。

通過 I2C 收發(fā)數(shù)據(jù)

在注冊好 I2C 驅(qū)動后,即可進(jìn)行 I2C 通訊。

向從機(jī)發(fā)送信息:

int i2c_master_send(const struct i2c_client *client, const char *buf, int count) { int ret; struct i2c_adapter *adap = client->adapter; struct i2c_msg msg; msg.addr = client->addr; msg.flags = client->flags & I2C_M_TEN; msg.len = count; msg.buf = (char *)buf; ret = i2c_transfer(adap, &msg, 1); /* + If everything went ok (i.e. 1 msg transmitted), return #bytes + transmitted, else error code. */ return (ret == 1) ? count : ret; }

向從機(jī)讀取信息:

int i2c_master_recv(const struct i2c_client *client, char *buf, int count) { struct i2c_adapter *adap = client->adapter; struct i2c_msg msg; int ret; msg.addr = client->addr; msg.flags = client->flags & I2C_M_TEN; msg.flags |= I2C_M_RD; msg.len = count; msg.buf = buf; ret = i2c_transfer(adap, &msg, 1); /* + If everything went ok (i.e. 1 msg received), return #bytes received, + else error code. */ return (ret == 1) ? count : ret; } EXPORT_SYMBOL(i2c_master_recv);

FAQs

Q1: 通信失敗,出現(xiàn)這種log:”timeout, ipd: 0x00, state: 1”該如何調(diào)試?

A1: 請檢查硬件上拉是否給電。

Q2: 調(diào)用i2c_transfer返回值為-6?

A2: 返回值為-6表示為NACK錯(cuò)誤,即對方設(shè)備無應(yīng)答響應(yīng),這種情況一般為外設(shè)的問題,常見的有以下幾種情況:

I2C地址錯(cuò)誤,解決方法是測量I2C波形,確認(rèn)是否I2C 設(shè)備地址錯(cuò)誤;

I2C slave 設(shè)備不處于正常工作狀態(tài),比如未給電,錯(cuò)誤的上電時(shí)序等;

時(shí)序不符合 I2C slave設(shè)備所要求也會產(chǎn)生Nack信號

Q3: 當(dāng)外設(shè)對于讀時(shí)序要求中間是stop信號不是repeat start信號的時(shí)候,該如何處理?

A3: 這時(shí)需要調(diào)用兩次i2c_transfer, I2C read 拆分成兩次,修改如下:

static int i2c_read_bytes(struct i2c_client *client, u8 cmd, u8 *data, u8 data_len) { struct i2c_msg msgs[2]; int ret; u8 *buffer; buffer = kzalloc(data_len, GFP_KERNEL); if (!buffer) return -ENOMEM;; msgs[0].addr = client->addr; msgs[0].flags = client->flags; msgs[0].len = 1; msgs[0].buf = &cmd; ret = i2c_transfer(client->adapter, msgs, 1); if (ret < 0) { dev_err(&client->adapter->dev, "i2c read failed\n"); kfree(buffer); return ret; } msgs[1].addr = client->addr; msgs[1].flags = client->flags | I2C_M_RD; msgs[1].len = data_len; msgs[1].buf = buffer; ret = i2c_transfer(client->adapter, &msgs[1], 1); if (ret < 0) dev_err(&client->adapter->dev, "i2c read failed\n"); else memcpy(data, buffer, data_len); kfree(buffer); return ret; }

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

    關(guān)注

    87

    文章

    11161

    瀏覽量

    208459
  • 嵌入式主板
    +關(guān)注

    關(guān)注

    7

    文章

    6083

    瀏覽量

    35092
  • Firefly
    +關(guān)注

    關(guān)注

    2

    文章

    538

    瀏覽量

    6946
收藏 人收藏

    評論

    相關(guān)推薦

    fireflyAIO-3399J主板簡介

    AIO-3399J 的標(biāo)準(zhǔn)套裝包含以下配件
    的頭像 發(fā)表于 11-05 15:52 ?1480次閱讀
    <b class='flag-5'>fireflyAIO-3399J</b><b class='flag-5'>主板</b>簡介

    fireflyFace-RK3399主板I2C控制器介紹

    Face-RK3399 開發(fā)板上有 9 個(gè)片上 I2C 控制器,
    的頭像 發(fā)表于 12-04 09:17 ?2895次閱讀
    fireflyFace-RK<b class='flag-5'>3399</b><b class='flag-5'>主板</b><b class='flag-5'>I2C</b>控制器<b class='flag-5'>介紹</b>

    fireflyAIO-3399C--I2C主板控制器介紹

    AIO-3399C 開發(fā)板上有 9 個(gè)片上 I2C 控制器
    的頭像 發(fā)表于 12-13 10:05 ?1269次閱讀
    <b class='flag-5'>fireflyAIO-3399C--I2C</b><b class='flag-5'>主板</b>控制器<b class='flag-5'>介紹</b>

    fireflyAIO-3288J主板I2C簡介

    AIO-3288J 開發(fā)板上有 6 個(gè)片上 I2C 控制器。
    的頭像 發(fā)表于 12-20 10:05 ?1286次閱讀

    fireflyAIO-3399J主板接口定義介紹

    ,lineout),3.5mm耳機(jī)接口,RTC電源接口,12v電源接口,IR接口,TF卡槽,SIM卡卡槽,擴(kuò)展按鍵接口,I2C,I2S,喇叭接口,USB2.0 HOST,recovery/reset按鍵,EDP屏
    的頭像 發(fā)表于 12-24 09:52 ?1859次閱讀
    <b class='flag-5'>fireflyAIO-3399J</b><b class='flag-5'>主板</b>接口定義<b class='flag-5'>介紹</b>

    fireflyAIO-3399J主板介紹

    AIO-3399J默認(rèn)出廠固件是支持LVDS+HDMI 1080P的雙屏顯示,HDMI分辨率最高只能到1080P。
    的頭像 發(fā)表于 12-24 10:03 ?1608次閱讀
    <b class='flag-5'>fireflyAIO-3399J</b><b class='flag-5'>主板</b><b class='flag-5'>介紹</b>

    fireflyAIO-3399J主板紅外遙控器簡介

    紅外遙控器 產(chǎn)品參數(shù) 產(chǎn)品:12鍵紅外遙控器 版本:Firefly定制版 電源:兩節(jié)7號電池 適配:AIO-3399J 描述:支持AIO-3399J開發(fā)板的遙控開機(jī)功能
    的頭像 發(fā)表于 12-24 10:07 ?1503次閱讀

    fireflyAIO-3399J主板屏幕模組介紹

    屏幕模組 7.85寸MIPI液晶屏模組 注意:默認(rèn)的AIO-3399J主板不帶mipi_dsi接口,如需要此功能需修改硬件。
    的頭像 發(fā)表于 12-24 10:14 ?1567次閱讀
    <b class='flag-5'>fireflyAIO-3399J</b><b class='flag-5'>主板</b>屏幕模組<b class='flag-5'>介紹</b>

    fireflyAIO-3399J主板UART使用介紹

    AIO-3399J 支持SPI橋接/擴(kuò)展4個(gè)增強(qiáng)功能串口(UART)的功能,分別為UART1,UART2,RS232,RS485。
    的頭像 發(fā)表于 12-24 10:18 ?2045次閱讀
    <b class='flag-5'>fireflyAIO-3399J</b><b class='flag-5'>主板</b>UART使用<b class='flag-5'>介紹</b>

    fireflyAIO-3399J主板RTC使用簡介

    AIO-3399J開發(fā)板上有 一個(gè)集成于RK808上的RTC(Real Time Clock),主要功能有時(shí)鐘,日歷,鬧鐘,周期性中斷,雙通道32KHz時(shí)鐘輸出。
    的頭像 發(fā)表于 12-24 10:20 ?1898次閱讀
    <b class='flag-5'>fireflyAIO-3399J</b><b class='flag-5'>主板</b>RTC使用簡介

    fireflyAIO-3399J主板PWM使用介紹

    AIO-3399J開發(fā)板上有 4 路 PWM 輸出,分別為 PWM0 ~ PWM3,4路 PWM 分別使用在eDP背光、MIPI背光、VDDLOG供電、紅外IR。 本章主要描述如何配置 PWM。
    的頭像 發(fā)表于 12-24 10:37 ?2191次閱讀

    fireflyAIO-3399J主板LED使用介紹

    AIO-3399J 開發(fā)板上有 2 個(gè) LED 燈
    的頭像 發(fā)表于 12-24 10:31 ?2957次閱讀
    <b class='flag-5'>fireflyAIO-3399J</b><b class='flag-5'>主板</b>LED使用<b class='flag-5'>介紹</b>

    fireflyAIO-3399J主板IR使用簡介

    AIO-3399J 開發(fā)板上使用紅外收發(fā)傳感器 IR (在 mic 接口和喇叭接口之間)實(shí)現(xiàn)遙控功能,在IR接口處接上紅外接收器。
    的頭像 發(fā)表于 12-24 10:32 ?2098次閱讀
    <b class='flag-5'>fireflyAIO-3399J</b><b class='flag-5'>主板</b>IR使用簡介

    fireflyAIO-3399J主板ADC使用介紹

    AIO-3399J 開發(fā)板上的 AD 接口有兩種,分別為:溫度傳感器 (Temperature Sensor)、逐次逼近ADC (Successive Approximation Register)。
    的頭像 發(fā)表于 12-24 10:47 ?1639次閱讀

    fireflyAIO-3399J啟動模式說明主板

    AIO-3399J 有靈活的啟動方式。一般情況下,除非硬件損壞,AIO-3399J 開發(fā)板是不會變磚的。
    的頭像 發(fā)表于 12-25 16:28 ?1317次閱讀