<strike id="kiyse"></strike>
  • <tr id="kiyse"></tr>
  • <strike id="kiyse"></strike><samp id="kiyse"><tbody id="kiyse"></tbody></samp>
    <strike id="kiyse"><s id="kiyse"></s></strike>
    <tr id="kiyse"></tr>
    <noframes id="kiyse"><code id="kiyse"></code></noframes>
    <th id="kiyse"></th>
    <samp id="kiyse"></samp>
  • <th id="kiyse"><s id="kiyse"></s></th>
  • JAVA操作英創主板I2C接口簡介

     2017-9-26     作者:陳昌龍         
    文章標簽:JavaI2C

      2017年9月,英創在Linux的文件系統中移植了針對嵌入式Linux的JRE(Java Runtime Environment),能夠支持Java應用程序的運行。由于Java語言不能直接訪問硬件資源,英創提供了Java硬件支持包,主要支持的工控接口有:以太網、串口、CAN、GPIO、SPI、I2C、RTC等。本文主要介紹使用Java語言調用英創Java硬件支持包,操作英創主板I2C接口的過程。


    1、I2C簡介

      I2C(Inter-Integrated Circuit)總線是一種2線制(串行數據SDA、串行時鐘頻率SCL)的主從通訊協議,主要運用于器件之間的數據通訊。SDA和SCL雙向漏極開路(Open Drain)并利用電阻將電位上拉,同一個I2C總線上可以掛載多個I2C設備,如下圖所示。


    JAVA操作英創主板I2C接口簡介.gif

    圖1 I2C掛載設備示意圖


     JAVA操作英創主板I2C接口簡介.gif

    圖2 I2C時序圖


      I2C總線是電平有效,在SCL信號為高電平的時候采樣SDA信號。如上圖所示,其通信過程為:SDA從1變動到0,而SCL還是1時,表示開始數據傳輸。接下來的7位,就是設備的地址。緊接著的是讀寫標志,其為1時是讀取,為0則是寫。如果I2C總線上存在著和請求的地址相對應的設備,則從設備會發送一個ACK信號通知主設備,可以發送數據了。接到ACK信號后,主設備則發送一個8位的數據,然后等待ACK。當傳輸完畢之后,SCL保持為1,SDA從0變換到1時,表明傳輸結束。


    2、I2C傳輸數據結構

      英創提供的I2C傳輸數據結構源文件為emtronix.hardware.I2CParam.java。每一個I2CParam類實例代表一次I2C通信,其主要成員變量如下所示:

      public class I2CParam {

             public byte SlaveAddr;     //I2C從設備地址

             public char RegAddr;       //要訪問的I2C從設備寄存器地址

             public byte[] Databuf;     //寫入/讀出的數據緩存

      }


      其中,SlavaAddr是要訪問的從設備的地址,RegAddr是要訪問的從設備的寄存器地址,Databuf是用戶申請好的緩存區域,讀寫的長度由此緩存區域的長度(Databuf.length)決定。


    3、I2C傳輸接口函數

      英創提供的I2C傳輸接口源文件為emtronix.hardware.I2C.java。用戶在實例化I2C類后可以調用Open、Read、Write、Close對I2C硬件接口進行操作。I2C類的具體信息如下,其中mFd為設備描述符,用戶不用設置,由接口函數自動修改。


      public class I2C {

             private int mFd;

             public I2C() {

                    mFd = -1;

             }

             public void info() {

                    System.out.println("mfd " + mFd);

             }

             /**

              * 打開/dev/i2c-0設備

              * @return 成功返回非負設備描述符;失敗返回-1

              */

             public native int Open();

          

             /**

              * 從I2C總線發送一幀數據,從設備的地址和寄存器地址由i2cparam指定

              * @param i2cparam 指定發送從設備的地址和寄存器地址,以及攜帶的數據,數據長度由i2cParam.DataBuf.length決定

              * @return 成功返回非負;失敗返回-1

              */

             public native int Write(I2CParam i2cparam);

          

             /**

              * 從I2C總線讀一幀數據,從設備地址和寄存器地址由i2cparam指定

              * @param i2cparam 指定發送從設備的地址和寄存器地址,以及攜帶的數據,數據長度由i2cParam.DataBuf.length決定

              * @return 成功返回非負;失敗返回-1

              */

             public native int Read(I2CParam i2cparam);

          

             /**

              * 關閉I2C設備

              * @return 成功返回0;失敗返回-1

              */

             public native int Close();

      }


    4、I2C從設備(鍵盤)程序

      測試SPI接口的時候可以直接將MISO和MOSI短接就可以測試發送和接收數據,但I2C的測試不能,需要連接到真正的I2C從設備,根據其工作時序,完成I2C通信的測試。這里選擇英創ETA202 I2C鍵盤擴展模塊。英創已經封裝好了一個I2CKeypad.java類,對外提供OpenKeypad、ReadKeypad、CloseKeypad等接口來操作I2C鍵盤。這些接口的內部實現是通過I2C類的接口函數來完成對I2C鍵盤的操作。I2CKeyPad類的OpenKeypad接口主要內容如下:


      public int OpenKeypad()

             {

                    I2CParam i2cparam = new I2CParam();

                    ......

                    mI2C = new I2C();

                    mIrq = new IRQ();

                    //1. open i2c bus

                    if(mI2C.Open() < 0)

                    {

                           System.out.println("I2C open failed\n");

                           return -1;

                    }

                    // 2. config tca8418

                    i2cparam.SlaveAddr = TCA8418_ADDR;

                    for(i=0;i<TCA8418Config.length;i++) {

                           i2cparam.RegAddr = (char) (TCA8418Config[i].ControlReg & 0x0ffff);

                           i2cparam.Databuf = new byte[1];

                           i2cparam.Databuf[0] = TCA8418Config[i].Command;

                           if(mI2C.Write(i2cparam) < 0) {

                                  System.out.println("I2C write failed\n");

                                  return -1;

                           }

                    }

                    //3. open irq1

                    if(mIrq.Open("/dev/esm6800_irq1") < 0) {

                           System.out.println("can not open irq");

                           return -1;

                    }

                    ...

                    //4. 開啟中斷處理線程

                    scanThread = new Thread(new Runnable() {

                           public void run() {

                                  mIrq.setTimeout(1000);

                                  while(!Thread.currentThread().isInterrupted()) {

                                         if(mIrq.WaitForIrq()>0) {

                                                KeyScan();

                                         }

                                  }

                                  System.out.println("scanThread exit");

                           }

                    });

                    scanThread.start();

             }


      I2CKeypad類在OpenKeyPad接口中使用I2C的Write接口對鍵盤掃描芯片tca8418進行了初始化設置,并開啟了監聽中斷處理線程。中斷處理線程中的KeyScan函數調用了I2C的Read接口去讀取事件信息,更新按鍵值。tca8418的各個寄存器功能,請參考模塊ETA202中的數據手冊。I2CKeypad類具體實現請結合tca8418的數據手冊參考源碼。


    5、I2C鍵盤測試程序

      I2C傳輸接口中操作I2C的接口函數聲明都有native的前綴,表明其實現部分在本地的庫當中。英創將所有英創主板的硬件接口訪問函數的實現部分編譯成了動態鏈接庫libemtronixhardware.so,放在了文件系統/lib目錄下。


      在編寫I2C傳輸主程序的時候,首先需要加載該庫,如下所示:

      public class testI2CMain {

             static {

                    System.loadLibrary("emtronixhardware"); 

             }

             public static void main(String[] args) {

             ...

             }

      }


      然后,就可以在main函數中實例化I2CKeypad類,先調用OpenKeypad接口初始化鍵盤,接著可調用I2CKeypad的ReadKeypad接口讀取按鍵信息:

      public static void main(String[] args) {

                  I2CKeypad pad = new I2CKeypad();

                  int i1 = pad.OpenKeypad();

                  int key;

                  if(i1 < 0)

                  {

                         System.out.println("open keypad failed");

                         return;

                  }

                  for(i1 = 0; i1 < 10; ) {

                         key = pad.ReadKeypad();

                         if(key > 0) {

                                i1++;

                                System.out.println("-----key: 0x" + Integer.toHexString(key));

                         }

                  }

                  pad.CloseKeypad();

                 

                  return ;

           }


    6、I2C鍵盤測試程序運行結果

    運行I2C傳輸Java主程序需要把編譯結果bin文件中的所有目錄文件拷貝到主板/mnt/nandflash,或者通過nfs掛載到主板/mnt/nfs目錄下。然后,使用“java 包名.類名”運行,如下圖所示:


    JAVA操作英創主板I2C接口簡介.gif

    圖2 運行I2C鍵盤測試程序


      以上就是使用Java操作英創主板I2C接口的介紹,感興趣的客戶可以通過電話或者郵件聯系英創工程師。我們將提供Java示例程序源碼供客戶參考。

    文章標簽:JavaI2C
    国产香蕉久久精品综合网| 久久国产精品一区二区| 99热在线只有精品| 免费精品视频在线| 国产成人愉拍精品| 国精品无码一区二区三区在线 | 久久精品国产亚洲AV麻豆~| 国产精品无码久久av不卡| 蜜臀久久99精品久久久久久小说| 亚洲七七久久精品中文国产| 人人妻人人澡人人爽人人精品浪潮 | 日韩精品无码永久免费网站| 国产精品福利网站导航| 青青热久久久久综合精品| 国产精品情侣呻吟对白视频| 国产高清在线精品二区一| 久久国产精品久久精品国产| 亚洲精品国产精品国自产观看 | 亚洲精品国产成人| 久久久久夜夜夜精品国产| 国产成人精品久久亚洲高清不卡 国产成人精品久久亚洲 | 国产精品毛片久久久久久久 | 久热中文字幕在线精品免费| 国产成人精品AA毛片| 国产精品最新国产精品第十页| 国产馆精品推荐在线观看| 99久久国产综合精品五月天| 99久热只有精品视频免费看| 国产在线精品一区二区不卡| 精品国产AⅤ一区二区三区4区 | 91精品国产色综合久久| 精品无码中出一区二区| 青草青草久热精品观看| 免费精品国产自产拍在线观看图片| 蜜芽亚洲av无码精品色午夜| 亚洲国产精品SSS在线观看AV| 国产亚洲精品精品国产亚洲综合| 青青热久久国产久精品 | 99国产精品久久久久久久成人热| 亚洲国产婷婷综合在线精品| 国产精品久久久久久久久99热|