在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

Firefly-RK3128主板ADC簡介

firefly ? 來源:firefly ? 作者:firefly ? 2019-11-28 17:17 ? 次閱讀
ADC 使用
前言

Firefly-RK3128 開發板有一個 3 通道(0/1/2)、10 比特精度的 SAR ADC (Successive Approximation Register,逐次逼近寄存器),其中:

  • ADCIN0: 在擴展板中引出
  • ADCIN1: 內部作 Recovery 鍵檢測
  • ADCIN2: 在擴展板中引出

本文主要介紹 ADC 的基本使用方法。

配置DTS節點

Firefly-RK3128 ADC 的 DTS 節點在 kernel/arch/arm/boot/dts/rk312x.dtsi 文件中定義,如下所示:

adc: adc@2006c000 {compatible = "rockchip,saradc"; reg = <0x2006c000 0x100>; interrupts = <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>; #io-channel-cells = <1>; io-channel-ranges; rockchip,adc-vref = <1800>; clock-frequency = <1000000>; clocks = <&clk_saradc>, <&clk_gates7 14>; clock-names = "saradc", "pclk_saradc"; status = "disabled"; };

用戶只需在 rk3128-fireprime.dts 文件中添加通道定義,并將其 status 改為 “okay” 即可:

&adc { status = "okay"; adc_test {status = "okay"; compatible = "rk-adc-test"; io-channels = <&adc 0>; };

此處添加一個測試設備 adc_test,為下面的驅動測試例程所使用。

ADC 的驅動源碼為 drivers/iio/adc/rockchip_adc.c

獲取 ADC 通道
struct iio_channel *chan;chan = iio_channel_get(&pdev->dev, "adc0");

adc0 為通道名稱,可用的通道列表在 rockchip_adc.c 中定義:

static const struct iio_chan_spec rk_adc_iio_channels[] = { ADC_CHANNEL(0, "adc0"),ADC_CHANNEL(1, "adc1"),ADC_CHANNEL(2, "adc2"),ADC_CHANNEL(6, "adc6"), };
讀取 AD 采集到的原始數據
int val, ret;ret = iio_read_channel_raw(chan, &val);

調用 iio_read_channel_raw 函數讀取 ADC 采集的原始數據并存入 val 中。

計算采集到的電壓

使用標準電壓將 AD 轉換的值轉換為用戶所需要的電壓值。其計算公式如下:

Vref / (2^n-1) = Vresult / raw

注: Vref 為標準電壓 n 為 AD 轉換的位數 Vresult 為用戶所需要的采集電壓 raw 為 AD 采集的原始數據 例如,標準電壓為 1.8V,AD 采集位數為 10 位,AD 采集到的原始數據為 568,則:

Vresult = (1800mv * 568) / 1023;
驅動測試例程

以下為完整的讀取 ADC 的驅動例程:

#include #include #include #include #include #include #include #include #include #include struct iio_channel *adc_test_channel; static ssize_t show_measure(struct device *dev, struct device_attribute *attr, char *buf){ int val, ret; size_t count = 0; ret = iio_read_channel_raw(adc_test_channel, &val); if (ret < 0) { count += sprintf(&buf[count], "read channel() error: %d\n", ret); } else { count += sprintf(&buf[count], "read channel(): %d\n", val); } return count; } static struct device_attribute measure_attr =__ATTR(measure, S_IRUGO, show_measure, NULL); static int rk_adc_test_probe(struct platform_device *pdev) { struct iio_channel *channels;channels = iio_channel_get_all(&pdev->dev); if (IS_ERR(channels)) { pr_err("get adc channels fails\n"); goto err; } adc_test_channel = &channels[0]; if (device_create_file(&pdev->dev, &measure_attr)) { pr_err("device create file failed\n"); goto err; } err: return -1; } static int rk_adc_test_remove(struct platform_device *pdev) { device_remove_file(&pdev->dev, &measure_attr); iio_channel_release(adc_test_channel); adc_test_channel = NULL;return 0; } static const struct of_device_id rk_adc_test_match[] = { { .compatible = "rk-adc-test" }, {}, }; MODULE_DEVICE_TABLE(of, rk_adc_test_match); static struct platform_driver rk_adc_test_driver = { .probe = rk_adc_test_probe, .remove = rk_adc_test_remove, .driver = { .name = "rk-adc-test", .owner = THIS_MODULE, .of_match_table = rk_adc_test_match, } }; module_platform_driver(rk_adc_test_driver);

將以上源碼保存為 drivers/iio/adc/rockchip-adc-test.c ,并在 drivers/iio/adc/Makefile 后加入:

obj-$(CONFIG_ROCKCHIP_ADC) += rk_adc_test.o

編譯并燒寫內核和 resource.img,啟動后即可在終端下運行以下命令來讀取 ADC0 的值:

while true; do cat /sys/devices/2006c000.adc/adc_test.*/measure; sleep 1; done

注意,該例程并沒有采用 iio_channel_get 來獲取通道,而是調用 iio_channel_get_all, 讀取 io-channels 屬性所聲明的通道列表,后取首個通道:

struct iio_channel *channels;channels = iio_channel_get_all(&pdev->dev); if (IS_ERR(channels)) { pr_err("get adc channels fails\n"); goto err; } adc_test_channel = &channels[0];
ADC 常用函數接口
struct iio_channel *iio_channel_get(struct device *dev, const char *consumer_channel);
  • 功能:獲取 iio 通道描述
  • 參數:
    • dev: 使用該通道的設備描述指針
    • consumer_channel: 通道名稱
void iio_channel_release(struct iio_channel *chan);
  • 功能:釋放 iio_channel_get 函數獲取到的通道
  • 參數:
    • chan:要被釋放的通道描述指針
int iio_read_channel_raw(struct iio_channel *chan, int *val);
  • 功能:讀取 chan 通道 AD 采集的原始數據。
  • 參數:
    • chan:要讀取的采集通道指針
    • val:存放讀取結果的指針

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

    關注

    87

    文章

    11406

    瀏覽量

    212087
  • 嵌入式主板
    +關注

    關注

    7

    文章

    6094

    瀏覽量

    36054
  • Firefly
    +關注

    關注

    2

    文章

    540

    瀏覽量

    7301
收藏 人收藏

    評論

    相關推薦

    如何解決firefly rk3128 linux內核適配問題?

    如何解決firefly rk3128 linux內核適配問題?
    發表于 03-04 06:17

    Firefly-RK3128開發板上手教程(上)

    1、Firefly-RK3128開發板入手指南配件Firefly-RK3128 的標準套裝包含以下配件:Core-3128J 核心板一塊Firefly-RK3128 基板一塊WiFi
    發表于 08-12 17:32

    Firefly-RK3128開發板上手教程(下)

    1、如何將主機上的固件文件通過雙公頭USB數據線燒錄到開發板的閃存中準備工作Firefly-RK3128 開發板固件主機良好的 Micro USB OTG 線固件文件一般有兩種:單個統一固件
    發表于 08-12 17:51

    Firefly-RK3128 MIPI DSI使用步驟說明

    screen-type屬性:顯示屏類型,Firefly-RK3128只支持單通道MIPI屏,配置成SCREEN_MIPI即可。lvds-format屬性:無關選項。out-face屬性:配置顏色,可為OUT_P888
    發表于 08-22 17:12

    Firefly-RK3288--教程

    Firefly-RK3288 的標準套裝包含以下配件:   Firefly-RK3288 主板一塊   WiFi 天線   亞克力
    的頭像 發表于 11-11 16:04 ?4763次閱讀
    <b class='flag-5'>Firefly-RK</b>3288--教程

    firefly RK3128開發板介紹

    Firefly-RK3128 采用Cortex-A7架構四核1.3GHz處理器,集成Mali-400MP2 GPU, 擁有優秀的運算與圖形處理能力;板載千兆以太網口、2.4GHz Wi-Fi和藍牙4.0
    的頭像 發表于 11-14 11:27 ?4849次閱讀
    <b class='flag-5'>firefly</b> <b class='flag-5'>RK3128</b>開發板介紹

    Firefly-RK3128開發板UART接口介紹

    refly-RK3128 開發板內置 3 路 UART,分別為 uart0,uart1,uart2。uart0 用于藍牙數據傳輸,如果要使用 uart0,必須關掉藍牙,才可以使用擴展槽上的 UART0 針腳。
    的頭像 發表于 11-28 16:36 ?3584次閱讀
    <b class='flag-5'>Firefly-RK3128</b>開發板UART接口介紹

    Firefly-RK3128主板PWM輸出介紹

    Firefly-RK3128 開發板上有 4 路 PWM 輸出,分別為 PWM0 ~ PWM3
    的頭像 發表于 11-28 16:56 ?2594次閱讀
    <b class='flag-5'>Firefly-RK3128</b><b class='flag-5'>主板</b>PWM輸出介紹

    Firefly-RK3128主板LED子系統介紹

    Firefly-RK3128 開發板上有 2 個 LED 燈
    的頭像 發表于 11-28 17:01 ?2886次閱讀
    <b class='flag-5'>Firefly-RK3128</b><b class='flag-5'>主板</b>LED子系統介紹

    Firefly-RK3128主板I2C控制器

    Firefly-RK3128 開發板上有 4 個片上 I2C 控制器。本文主要描述如何在該開發板上配置 I2C。
    的頭像 發表于 11-29 08:47 ?1663次閱讀
    <b class='flag-5'>Firefly-RK3128</b><b class='flag-5'>主板</b>I2C控制器

    Firefly-RK3128開發板攝像頭的介紹

    Firefly-RK3128 開發板上有 CIF 接口,支持 CIF 攝像頭。
    的頭像 發表于 11-28 16:48 ?4025次閱讀
    <b class='flag-5'>Firefly-RK3128</b>開發板攝像頭的介紹

    Firefly-RK3128主板接口定義介紹

    Firefly-RK3128 開發板提供了豐富的接口,主要包括:HDMI、音頻數字光纖、以太網、電源接口、復位按鍵、電源鍵、音頻輸入輸出、硅麥、串口調試接口、紅外接收、OTG接口、TF卡槽、USB Host1~4、
    的頭像 發表于 11-29 08:45 ?3692次閱讀
    <b class='flag-5'>Firefly-RK3128</b><b class='flag-5'>主板</b>接口定義介紹

    FireflyRK3128主板外殼介紹

    外殼 Firefly-RK3128 CAD圖 核心板 底板 Firefly-RK3128 外殼亞克力CAD圖
    的頭像 發表于 11-29 09:19 ?1360次閱讀
    FireflyRK<b class='flag-5'>3128</b><b class='flag-5'>主板</b>外殼介紹

    Firefly-RK3128主板啟動模式簡介

    Firefly-RK3128 有靈活的啟動方式。
    的頭像 發表于 11-29 09:27 ?5611次閱讀

    Firefly-RK3128主板串口調試

    Firefly-RK3128 開發板的調試串口與 TF 卡接口有信號引腳復用,因此無法同時使用
    的頭像 發表于 11-29 09:47 ?3839次閱讀
    <b class='flag-5'>Firefly-RK3128</b><b class='flag-5'>主板</b>串口調試
    主站蜘蛛池模板: 欧美怡红院免费全视频 | 欧美成人一区二区三区在线视频 | 美女网站色在线观看 | 亚洲色吧| 国产 麻豆 | 97天天做天天爱夜夜爽 | 日本亚洲视频 | 日韩欧美亚洲一区 | 日本一区二区在线视频 | 五月天亚洲婷婷 | 天天干狠狠操 | 国产热 | 女生扒开尿口让男生舔 | 最新版天堂资源官网 | 日韩免费高清一级毛片在线 | 网址色| 97人人模人人揉人人捏 | yiren22亚洲综合高清一区 | 狠狠做久久深爱婷婷97动漫 | 哟交小u女国产精品视频 | 天天操夜夜操天天操 | 狠狠色成人综合首页 | 天天干天天草天天射 | 欧美极品色影院 | 国产精品伦理一区二区三区 | 色综合久| 亚洲第一久久 | 亚洲人成伊人成综合网久久 | 特级毛片免费视频播放 | 欧美日本俄罗斯一级毛片 | 一区二区三区国模大胆 | 在线伊人网 | 免费在线观看的视频 | 人人天天爱天天做天天摸 | 亚洲日本欧美日韩高观看 | 男生脱美女内裤内衣动态图 | 天天干天天添 | 五月天婷婷在线观看高清 | 天天爱天天操天天射 | 色视频www在线播放国产人成 | 日本黄色录像视频 |