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

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

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

Linux 開發(fā)IIO子系統(tǒng)入門

工程師 ? 來源:一口Linux ? 作者:一口Linux ? 2020-10-27 10:44 ? 次閱讀

前陣子工作上做了一些關(guān)于 ADC 的支持,由于現(xiàn)在 ADC 相關(guān)的支持都被移動到了 IIO (Industrial I/O) 子系統(tǒng)下,我查閱了一些關(guān)于 IIO 資料,包括書籍、文章、內(nèi)核文檔和代碼。個人感覺最好的入門文章應(yīng)該是 ST WiKi 網(wǎng)站上 的 IIO Overview(2019) 和Analog Device Wiki 網(wǎng)站上的 Linux Industrial I/O Subsystem(2017),為了方便愛偷懶或者英文不好的小伙伴,我提煉了多篇文章的精華內(nèi)容并在其基礎(chǔ)上進行完善,盡量控制篇幅,希望能給大家提供一點小小的幫助。

Linux 驅(qū)動開發(fā) / IIO子系統(tǒng)入門1

正文目錄:

1. 什么是 IIO 子系統(tǒng)? 1.1 IIO 概述 1.2 IIO 相關(guān)的組件2. IIO 功能特性3. IIO 相關(guān)配置 3.1 配置內(nèi)核 3.2 配置設(shè)備樹 3.2.1 IIO providers 3.2.2 IIO consumers4. IIO API 4.1 用戶空間 API 4.1.1 4種接口 4.1.2 操作實例5. 更多值得學(xué)習(xí)的知識點6. 相關(guān)參考

寫作目的:

整理一些 IIO 子系統(tǒng)的入門知識。

1. 什么是 IIO 子系統(tǒng)?

1.1 IIO 概述

Industrial I/O 子系統(tǒng)旨在為某種意義上是模數(shù)或數(shù)模轉(zhuǎn)換器 (ADC,DAC) 的設(shè)備提供支持,于2009年由 Huawei 的 Jonathan Cameront 添加。

簡單框圖:

支持的設(shè)備包括:

ADC / DAC加速度計磁力計陀螺儀壓力傳感器濕度傳感器溫度傳感器。。.

很久以前,對于上述硬件的支持散落在 Linux 源碼中的各種地方。

IIO 的出現(xiàn),提供了一個統(tǒng)一的框架用于訪問和控制上述各種類型的傳感器,并且為用戶態(tài)應(yīng)用訪問傳感器提供了標準的接口:sysfs/devfs,并且填補了 Hwmon 和 Input 子系統(tǒng)之間的空白。

另外,IIO 不僅可以支持低速的 SoC ADC,還可支持高速、高數(shù)據(jù)速率的工業(yè)設(shè)備,例如 100M samples/sec 工業(yè) ADC。

1.2 IIO 相關(guān)的組件

IIO-overview

上圖基于 STM32 MPU,來源見文末。

1) 客戶端應(yīng)用程序(用戶空間):

該組件會使用 libiio 庫來配置 IIO 設(shè)備,然后從 IIO 設(shè)備讀數(shù)據(jù)或者寫數(shù)據(jù)到 IIO 設(shè)備中??蛻舳顺绦蚩梢约毞譃?local client 和 remote client。

2) libiio 庫(用戶空間):

libiio 是 Analog Device 公司發(fā)起的一個用于訪問 IIO 設(shè)備的開源庫。

它封裝了對 /sys/bus/iio/devices(配置 iio) 和/dev/iio/deviceX(讀寫iio) 的訪問,并且提供了便于測試的 iio 命令行工具 (iio_info / iio_readdev) 和 iiod server。

iiod server 內(nèi)含 local backend 和 remote backend 以支持 local client 和 remote client 的訪問。

libiio 的源碼位于:github libiio

3) 訪問接口(用戶空間):

iio 支持多種標準的 Linux 設(shè)備訪問接口:

char device, sysfs, configfs, debugfs。

4) 內(nèi)核空間的 iio 消費者(即 IIO consumers):

除了用戶空間的應(yīng)用程序能訪問 iio 設(shè)備之外,在內(nèi)核里也有其他設(shè)備驅(qū)動需要使用 iio 子系統(tǒng)的 API 來編寫符合自身框架的設(shè)備驅(qū)動。

例如在 iio 子系統(tǒng)里支持了某款 Soc ADC 后,可能會有不同的硬件設(shè)備接到該 ADC 通道上,典型的例子是觸摸芯片,開發(fā)人員需要在 input 子系統(tǒng)的框架下編寫 touch driver,在 touch driver的 irq handler 中 調(diào)用 iio in-kern API 來讀取觸摸屏的 X、Y 值。

iio in-kernl API的定義位于頭文件:

include/linux/iio/consumer.h

5) IIO framework(內(nèi)核空間):

IIO 子系統(tǒng)的核心實現(xiàn)。

6) IIO device driver(或稱 IIO providers):

7) Linux 內(nèi)核自帶的 IIO 調(diào)試工具:

2. IIO 的功能特性

1) 基礎(chǔ)的設(shè)備注冊和訪問

類似于 hwmon 子系統(tǒng),它們都可以通過 sysfs 以輪循的方式訪問設(shè)備;

2) 可讀取事件的字符設(shè)備(Event chrdevs)

類似于 input 子系統(tǒng),iio 子系統(tǒng)也可以向應(yīng)用層上報事件(hardware triggered events),例如閾值檢測事件,自由落體檢測事件、更復(fù)雜的動作檢測事件;

目前 event 的格式為:event code + 時間戳;

3) 支持硬件 buffer

4) 支持 Trigger 和軟件 buffer

3. IIO 相關(guān)配置

3.1 配置內(nèi)核

Linux-4.14:

$ make menuconfigDevice Drivers ---》 《*》 Industrial I/O support ---》 [*] Enable buffer support within IIO 《 》 IIO callback buffer used for push in-kernel interfaces 《*》 Industrial I/O HW buffering 《*》 Industrial I/O buffering based on kfifo 《 》 Enable IIO configuration via configfs [*] Enable triggered sampling support (2) Maximum number of consumers per trigger 《 》 Enable software triggers support Accelerometers ---》 Analog to digital converters ---》 Amplifiers ---》 Chemical Sensors ---》 Hid Sensor IIO Common ---- SSP Sensor Common ---》 Digital to analog converters ---》 IIO dummy driver ---》 Frequency Synthesizers DDS/PLL ---》 Digital gyroscope sensors ---》 Health Sensors ---》 Humidity sensors ---》 Inertial measurement units ---》 Light sensors ---》 Magnetometer sensors ---》 Inclinometer sensors ---- Triggers - standalone ---》 Digital potentiometers ---》 Pressure sensors ---》 Lightning sensors ---》 Proximity sensors ---》 Temperature sensors ---》

從配置項的數(shù)目來看,IIO 的用途真的很廣泛。

3.2 配置設(shè)備樹

3.2.1 IIO providers

1) 相關(guān)要點:

IIO channels 源在設(shè)備樹中用 IIO providers 來指定;

2) 必要屬性:

io-channel-cells,0 表示只有 1 路 IIO output,1 表示有多路 IIO output;

io-channel-ranges: 一個 empty 屬性(即不用賦值),會在 driver/iio/inkern.c/iio_channel_get() 中被引用,它表明繼承了當前節(jié)點的子節(jié)點可以引用當前節(jié)點的 IIO channel;

3) 例子1 (no trigger)

adc: voltage-sensor@35 { compatible = “maxim,max1139”; reg = 《0x35》; #io-channel-cells = 《1》;};

4) 例子2 (with trigger)

adc@35 { compatible = “some-vendor,some-adc”; reg = 《0x35》; adc1: iio-device@0 { #io-channel-cells = 《1》; /* other properties */ }; adc2: iio-device@1 { #io-channel-cells = 《1》; /* other properties */ };};

3.2.2 IIO consumers

1) 相關(guān)要點:

IIO consumer 節(jié)點的形式是 《phandle iio_specifier》;

它的作用是連接 IIO provider 的 input 端到 IIO consumer 的 output 端;

其中,phandle 是 IIO provider 的句柄,specifier 用于選擇第幾路 channel;

類似 gpio specifier, IIO specifier 是有 1 個或者多個 cells 的數(shù)組,用于確定 IIO device的 output 端,即 1 個 cell 對應(yīng)一個 IIO channel output;

IIO specifier 數(shù)組的長度由 IIO provider 節(jié)點的 #io-channel-cells 屬性決定;

2) 必要屬性:

io-channels:《phandle iio_specifier》 列表, 一個《phandle iio_specifier》 代表該設(shè)備連接著的一路 IIO input。如果 IIO provider 的 io-channel-cells=0 (即只有1路 IIO output), 則省略 iio_specifier。

3) 可選屬性:

io-channel-names: IIO input 的名稱列表,順序要和 io-channels 屬性保持一致,Consumers drivers 會將該名稱和 iio_specifier 指定的 IIO input match 到一起。

4) 例子1

some_consumer { io-channels = 《&adc 1》, 《&ref 0》; io-channel-names = “vcc”, “vdd”; };

上述例子的引用了provider &adc的第1路 channel,和proiver &ref的第0路 channel。

4. IIO API

4.1 用戶空間 API

相關(guān)參考:

IIO user space interface

How to use the IIO user space interface

4.1.1 4種接口

1)。 sysfs interface

/sys/bus/iio/devices/iio:deviceX;

可用于配置 /dev/iio:deviceX 接口的 events / data

可用于輪循的方式低速地直接讀/寫 IIO 設(shè)備;

Documentation/ABI/testing/sysfs-bus-iio;

2)。 character device

/dev/iio:deviceX,該接口在 IIO 子系統(tǒng)里是可選非必要的;

標準的文件 IO API: open(), read(), write(), close()。

用于讀取 events 和 data;

3)。 configfs

用于配置額外的 IIO特性,例如:軟件 triggers 或者 hrtimer triggers;

詳細說明:

Documentation/ABI/testing/configfs-iio;

Documentation/iio/iio_configfs.txt;

4)。 debugfs

一些調(diào)試功能,例如 direct_reg_access 節(jié)點可用于讀寫寄存器;

4.1.2 操作實例

IIO direct mode: 通過 sysfs 以輪循的方式讀 ADC 或者寫 DAC:

1) 直接讀 ADC

確定 sysfs 節(jié)點(方式1,不依賴工具)

$ grep -H “” /sys/bus/iio/devices/*/name | grep adc/sys/bus/iio/devices/iio:device0/name:48003000.adc:adc@0/sys/bus/iio/devices/iio:device1/name:48003000.adc:adc@1

sysfs 中的 iio:device0 sysfs 對應(yīng) ADC1;

$ cd /sys/bus/iio/devices/iio:device0/$ cat in_voltage6_raw # Convert ADC1 channel 0 (analog-to-digital): get raw value40603$ cat in_voltage_scale # Read scale0.044250488$ cat in_voltage_offset # Read offset0$ awk “BEGIN{printf (\”%d\n\“, (40603 + 0) * 0.044250488)}”1796

計算公式: Scaled value = (raw + offset) * scale = 1796 mV;

2) 直接寫 DAC

確定 sysfs 節(jié)點(方式2)

$ lsiio | grep dacDevice 003: 40017000.dac:dac@1Device 004: 40017000.dac:dac@2

sysfs 中的 iio:device3 sysfs 對應(yīng) DAC1,lsiio 來源于Linux 內(nèi)核源碼(tools/iio/)。

$ cd /sys/bus/iio/devices/iio:device3/$ cat out_voltage1_scale # Read scale0.708007812$ awk “BEGIN{printf (\”%d\n\“, 2000 / 0.708007812)}” # 假設(shè)要輸出 2000 mV2824$ echo 2824 》 out_voltage1_raw # Write raw value to DAC1$ echo 0 》 out_voltage1_powerdown # Enable DAC1 (out of power-down mode)

5. 更多值得學(xué)習(xí)的知識點

以 timer triggers 和 buffers 的方式讀 ADC 或者寫 DAC;

IIO 內(nèi)核空間 API;

編寫 IIO device driver

編寫 IIO consumer driver

鑒于大多數(shù)人的注意力無法在一篇文章里上集中太久,更多的內(nèi)容請大家先自行去閱讀吧,不是自己理解到的東西是消化不了的。有機會的話我會把更多的讀書心得放在后面的文章。

6. 相關(guān)參考

IIO Overview

Linux Industrial I/O Subsystem

《Linux Device Drivers Development》

本文只是一篇入門的文章,仍然有許多細節(jié)的知識點沒有被描述到。如果本文能讓你對 IIO 子系統(tǒng)有個大概的認識,那么本文的目的也就算達成了,以后還會繼續(xù)寫更多 IIO 子系統(tǒng)的文章。

責(zé)任編輯:haq

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

    關(guān)注

    27

    文章

    8707

    瀏覽量

    147252
  • adc
    adc
    +關(guān)注

    關(guān)注

    98

    文章

    6501

    瀏覽量

    544771
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11310

    瀏覽量

    209620
收藏 人收藏

    評論

    相關(guān)推薦

    Linux,IIO驅(qū)動完結(jié)有感

    1. 我錄制45天,你學(xué)完只需要1天 歷時1個半月,驅(qū)動大全IIO驅(qū)動完結(jié)了!20個視頻,時長5小時45分鐘。大綱如下: 01.1_IIO子系統(tǒng)簡化框架01.2_DHT11操作原理與編程思路
    的頭像 發(fā)表于 12-06 09:45 ?207次閱讀
    <b class='flag-5'>Linux</b>,<b class='flag-5'>IIO</b>驅(qū)動完結(jié)有感

    Linux從零到精通:最簡單的Shell腳本入門教程

    在數(shù)字化時代的浪潮中,Linux操作系統(tǒng)憑借其高效、穩(wěn)定、開源的特性,成為了無數(shù)開發(fā)者和系統(tǒng)管理員的首選。 而在Linux的龐大生態(tài)
    的頭像 發(fā)表于 12-05 09:56 ?458次閱讀
    <b class='flag-5'>Linux</b>從零到精通:最簡單的Shell腳本<b class='flag-5'>入門</b>教程

    【北京迅為】itop-龍芯2k1000開發(fā)指南Linux基礎(chǔ)入門vim 編輯器

    【北京迅為】itop-龍芯2k1000開發(fā)指南Linux基礎(chǔ)入門vim 編輯器
    的頭像 發(fā)表于 10-25 14:56 ?316次閱讀
    【北京迅為】itop-龍芯2k1000<b class='flag-5'>開發(fā)</b>指南<b class='flag-5'>Linux</b>基礎(chǔ)<b class='flag-5'>入門</b>vim 編輯器

    【驅(qū)動教程】iTOP-RK3568開發(fā)板進行講解第十三期,主要講解輸入子系統(tǒng),共計24 講

    驅(qū)動視頻全新升級,并持續(xù)更新~更全,思路更科學(xué),入門更簡單。 迅為基于iTOP-RK3568開發(fā)板進行講解,本次更新內(nèi)容為第十三期,主要講解輸入子系統(tǒng),共計24 講。 學(xué)習(xí)鏈接 本期視頻教程已上傳至
    發(fā)表于 10-11 11:31

    深度解析linux時鐘子系統(tǒng)

    linux內(nèi)核中實現(xiàn)了一個CLK子系統(tǒng),用于對上層提供各模塊(例如需要時鐘信號的外設(shè),USB等)的時鐘驅(qū)動接口,對下層提供具體SOC的時鐘操作細節(jié)。
    的頭像 發(fā)表于 09-29 16:46 ?483次閱讀
    深度解析<b class='flag-5'>linux</b>時鐘<b class='flag-5'>子系統(tǒng)</b>

    Linux 驅(qū)動開發(fā)與應(yīng)用開發(fā),你知道多少?

    一、Linux驅(qū)動開發(fā)與應(yīng)用開發(fā)的區(qū)別開發(fā)層次不同:Linux驅(qū)動開發(fā)主要是針對硬件設(shè)備進行編程
    的頭像 發(fā)表于 08-30 12:16 ?804次閱讀
    <b class='flag-5'>Linux</b> 驅(qū)動<b class='flag-5'>開發(fā)</b>與應(yīng)用<b class='flag-5'>開發(fā)</b>,你知道多少?

    linux--LED子系統(tǒng)一文讀懂

    Linux內(nèi)核中,LED子系統(tǒng)扮演著控制LED燈的核心角色,它通過一套規(guī)范化的驅(qū)動架構(gòu),簡化了LED驅(qū)動程序的開發(fā)流程,讓開發(fā)者能夠更專注于功能實現(xiàn)而非硬件層面的復(fù)雜性。
    的頭像 發(fā)表于 08-02 16:09 ?2555次閱讀
    <b class='flag-5'>linux</b>--LED<b class='flag-5'>子系統(tǒng)</b>一文讀懂

    【出版發(fā)行】嵌入式系統(tǒng)原理與開發(fā)——基于RISC-V和Linux系統(tǒng)

    【出版發(fā)行】嵌入式系統(tǒng)原理與開發(fā)——基于RISC-V和Linux系統(tǒng)
    的頭像 發(fā)表于 07-26 08:36 ?336次閱讀
    【出版發(fā)行】嵌入式<b class='flag-5'>系統(tǒng)</b>原理與<b class='flag-5'>開發(fā)</b>——基于RISC-V和<b class='flag-5'>Linux</b><b class='flag-5'>系統(tǒng)</b>

    鴻蒙開發(fā)圖形圖像:【圖形子系統(tǒng)

    圖形子系統(tǒng)主要包括UI組件、布局、動畫、字體、輸入事件、窗口管理、渲染繪制等模塊,構(gòu)建基于輕量OS應(yīng)用框架滿足硬件資源較小的物聯(lián)網(wǎng)設(shè)備或者構(gòu)建基于標準OS的應(yīng)用框架滿足富設(shè)備的OpenHarmony系統(tǒng)應(yīng)用開發(fā)。
    的頭像 發(fā)表于 03-23 16:50 ?662次閱讀
    鴻蒙<b class='flag-5'>開發(fā)</b>圖形圖像:【圖形<b class='flag-5'>子系統(tǒng)</b>】

    鴻蒙開發(fā)學(xué)習(xí):【驅(qū)動子系統(tǒng)

    OpenHarmony驅(qū)動子系統(tǒng)采用C面向?qū)ο缶幊棠P蜆?gòu)建,通過平臺解耦、內(nèi)核解耦,兼容不同內(nèi)核,提供了歸一化的驅(qū)動平臺底座,旨在為開發(fā)者提供更精準、更高效的開發(fā)環(huán)境,力求做到一次開發(fā)
    的頭像 發(fā)表于 03-17 22:05 ?606次閱讀
    鴻蒙<b class='flag-5'>開發(fā)</b>學(xué)習(xí):【驅(qū)動<b class='flag-5'>子系統(tǒng)</b>】

    鴻蒙開發(fā)實戰(zhàn):【包管理子系統(tǒng)

    包管理子系統(tǒng)負責(zé)應(yīng)用安裝包的管理,提供安裝包的信息查詢、安裝、更新、卸載和包信息存儲等能力
    的頭像 發(fā)表于 03-14 15:23 ?694次閱讀
    鴻蒙<b class='flag-5'>開發(fā)</b>實戰(zhàn):【包管理<b class='flag-5'>子系統(tǒng)</b>】

    ARM嵌入式Linux 系統(tǒng)開發(fā)入門到精通

    ARM嵌入式Linux 系統(tǒng)開發(fā)入門到精通
    發(fā)表于 03-10 18:44

    迅為RK3568開發(fā)板驅(qū)動開發(fā)指南-輸入子系統(tǒng)

    迅為RK3568開發(fā)板驅(qū)動開發(fā)指南-輸入子系統(tǒng)
    的頭像 發(fā)表于 02-23 15:11 ?894次閱讀
    迅為RK3568<b class='flag-5'>開發(fā)</b>板驅(qū)動<b class='flag-5'>開發(fā)</b>指南-輸入<b class='flag-5'>子系統(tǒng)</b>

    盤點那些硬件+項目學(xué)習(xí)套件:STM32MP157 Linux開發(fā)板及入門常見問題解答

    Cortex-M4核,Cortex-A7核上可以跑Linux操作系統(tǒng),Cortex-M4核上可以跑FreeRTOS、RT-Thread等實時操作系統(tǒng)。開發(fā)板搭配仿真器(獨家配件可仿真A
    發(fā)表于 02-01 14:25

    arm開發(fā)板如何安裝linux系統(tǒng)

    安裝Linux系統(tǒng)到ARM開發(fā)板是一個復(fù)雜的過程,涉及到多個步驟和不同的工具。下面是一個詳實且細致的教程,包含了從準備工作到最終啟動Linux系統(tǒng)
    的頭像 發(fā)表于 01-24 14:19 ?3617次閱讀