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

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

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

3天內不再提示

fireflyAIO-3128C主板GPIO使用簡介

firefly ? 來源:firefly ? 作者:firefly ? 2019-12-24 08:52 ? 次閱讀

GPIO 使用

簡介

GPIO, 全稱 General-Purpose Input/Output(通用輸入輸出),是一種軟件運行期間能夠動態配置和控制的通用引腳。

AIO-3128C 有 4 組 GPIO bank: GPIO0,GPIO1, GPIO2, GPIO3。每組又以 A0~A7, B0~B7, C0~C7, D0~D7 作為編號區分。

每個 GPIO 口除了通用輸入輸出功能外,還可能有其它復用功能,例如 GPIO1_C2,可以復用成以下功能之一:

GPIO1_C2

SDMMC0_D0

UART2_TX

每個 GPIO 口的驅動電流、上下拉和重置后的初始狀態都不盡相同,詳細情況請參考《RK3128 規格書》中的 “RK3128 function IO description” 一章。

AIO-3128C 的 GPIO 驅動是在以下 pinctrl 文件中實現的:

kernel/drivers/pinctrl/pinctrl-rockchip.c

其核心是填充 GPIO bank 的方法和參數,并調用 gpiochip_add 注冊到內核中。

使用

開發板有兩個電源 LED 燈是 GPIO 口控制的,分別是:

從電路圖上看,GPIO 口輸出低電平時燈亮,高電平時燈滅。

輸入輸出

下面以電源 LED 燈的驅動為例,講述如何在內核編寫代碼控制 GPIO 口的輸出。

首先需要在 aio-3128c.dts 中增加驅動的資源描述:

firefly-led{ compatible = "firefly,led"; led-work = <&gpio1 GPIO_C6 GPIO_ACTIVE_LOW>; led-power = <&gpio1 GPIO_C7 GPIO_ACTIVE_LOW>; status = "okay"; };

這里定義了兩顆 LED 燈的 GPIO 設置:

led-work GPIO1_C6 GPIO_ACTIVE_LOW led-power GPIO1_C7 GPIO_ACTIVE_LOW

GPIO_ACTIVE_LOW 表示低電平有效(燈亮),如果是高電平有效,需要替換為 GPIO_ACTIVE_HIGH 。 之后在驅動程序中加入對 GPIO 口的申請和控制則可:

#ifdef CONFIG_OF #include #include #endif static int firefly_led_probe(struct platform_device *pdev) { int ret = -1; int gpio, flag; struct device_node *led_node = pdev->dev.of_node; gpio = of_get_named_gpio_flags(led_node, "led-power", 0, &flag); if (!gpio_is_valid(gpio)){ printk("invalid led-power: %d\n",gpio); return -1; } if (gpio_request(gpio, "led_power")) { printk("gpio %d request failed!\n",gpio); return ret; } led_info.power_gpio = gpio; led_info.power_enable_value = (flag == OF_GPIO_ACTIVE_LOW) ? 0 : 1; gpio_direction_output(led_info.power_gpio, !(led_info.power_enable_value)); ... on_error:gpio_free(gpio); }

of_get_named_gpio_flags 從設備樹中讀取 led-power 的 GPIO 配置編號和標志,gpio_is_valid 判斷該 GPIO 編號是否有效,gpio_request 則申請占用該 GPIO。如果初始化過程出錯,需要調用 gpio_free 來釋放之前申請過且成功的 GPIO 。

調用 gpio_direction_output 就可以設置輸出高還是低電平,因為是 GPIO_ACTIVE_LOW ,如果要燈亮,需要寫入 0 。

實際中如果要讀出 GPIO,需要先設置成輸入模式,然后再讀取值:

int val;gpio_direction_input(your_gpio);val = gpio_get_value(your_gpio);

下面是常用的 GPIO API 定義:

#include #include enum of_gpio_flags { OF_GPIO_ACTIVE_LOW = 0x1, }; int of_get_named_gpio_flags(struct device_node *np, const char *propname, int index, enum of_gpio_flags *flags); int gpio_is_valid(int gpio); int gpio_request(unsigned gpio, const char *label); void gpio_free(unsigned gpio); int gpio_direction_input(int gpio); int gpio_direction_output(int gpio, int v);

復用

如何定義 GPIO 有哪些功能可以復用,在運行時又如何切換功能呢?以 I2C1 為例作簡單的介紹。查規格表可知,I2C1_SDA 與 I2C1_SCL 的功能定義如下:

在 /kernel/arch/arm/boot/dts/rk312x.dtsi 里有:

i2c1: i2c@20056000 { compatible = "rockchip,rk30-i2c"; reg = <0x20056000 0x1000>; interrupts = ;#address-cells = <1>;#size-cells = <0>; pinctrl-names = "default", "gpio"; pinctrl-0 = <&i2c1_sda &i2c1_scl>; pinctrl-1 = <&i2c1_gpio>; gpios = <&gpio0 GPIO_A3 GPIO_ACTIVE_LOW>, <&gpio0 GPIO_A2 GPIO_ACTIVE_LOW>; clocks = <&clk_gates8 5>; rockchip,check-idle = <1>; status = "disabled"; };

此處,跟復用控制相關的是 pinctrl- 開頭的屬性:

pinctrl-names 定義了狀態名稱列表: default (i2c 功能) 和 gpio 兩種狀態。

pinctrl-0 定義了狀態 0 (即 default)時需要設置的 pinctrl: i2c1_sda 和 i2c1_scl

pinctrl-1 定義了狀態 1 (即 gpio)時需要設置的 pinctrl: i2c1_gpio

這些 pinctrl 在 /kernel/arch/arm/boot/dts/rk312x-pinctrl.dtsi 中定義:

/ { pinctrl: pinctrl@20008000 { compatible = "rockchip,rk312x-pinctrl"; ... gpio0_i2c1 { i2c1_sda:i2c1-sda { rockchip,pins = ; rockchip,pull = ; }; i2c1_scl:i2c1-scl { rockchip,pins = ; rockchip,pull = ; }; i2c1_gpio: i2c1-gpio { rockchip,pins = , ; rockchip,pull = ; }; }; }

I2C1_SDA, I2C1_SCL 的定義在 /kernel/arch/arm/boot/dts/include/dt-bindings/pinctrl/rockchip-rk312x.h 中:

#define GPIO0_A3 0x0a30#define I2C1_SDA 0x0a31#define MMC1_CMD 0x0a32 #define GPIO0_A2 0x0a20#define I2C1_SCL 0x0a21

FUN_TO_GPIO 的定義在 /kernel/arch/arm/boot/dts/include/dt-bindings/pinctrl/rockchip.h 中:

#define FUNC_TO_GPIO(m) ((m) & 0xfff0)

也就是說 FUNC_TO_GPIO(I2C1_SDA) == GPIO0_A3, FUNC_TO_GPIO(I2C1_SCL) == GPIO7_A2 。 像 0x0a31 這樣的值是有編碼規則的:

0 a3 1 | | `- func | `---- offset `------ bank

0x0a31 就表示 GPIO0_A3 func1, 即 I2C1_SDA 。

在復用時,如果選擇了 “default” (即 i2c 功能),系統會應用 i2c1_sda 和 i2c1_scl 這兩個 pinctrl,最終得將 GPIO0_A3 和 GPIO0_A2 兩個針腳切換成對應的 i2c 功能;而如果選擇了 “gpio” ,系統會應用 i2c1_gpio 這個 pinctrl,將 GPIO0_A3 和 GPIO0_A2 兩個針腳還原為 GPIO 功能。我們看看 i2c 的驅動程序 /kernel/drivers/i2c/busses/i2c-rockchip.c 是如何切換復用功能的:

static int rockchip_i2c_probe(struct platform_device *pdev){ struct rockchip_i2c *i2c = NULL; struct resource *res; struct device_node *np = pdev->dev.of_node; int ret; // ... i2c->sda_gpio = of_get_gpio(np, 0); if (!gpio_is_valid(i2c->sda_gpio)) { dev_err(&pdev->dev, "sda gpio is invalid\n"); return -EINVAL; } ret = devm_gpio_request(&pdev->dev, i2c->sda_gpio, dev_name(&i2c->adap.dev)); if (ret) { dev_err(&pdev->dev, "failed to request sda gpio\n"); return ret; } i2c->scl_gpio = of_get_gpio(np, 1); if (!gpio_is_valid(i2c->scl_gpio)) { dev_err(&pdev->dev, "scl gpio is invalid\n"); return -EINVAL; } ret = devm_gpio_request(&pdev->dev, i2c->scl_gpio, dev_name(&i2c->adap.dev)); if (ret) { dev_err(&pdev->dev, "failed to request scl gpio\n"); return ret; } i2c->gpio_state = pinctrl_lookup_state(i2c->dev->pins->p, "gpio"); if (IS_ERR(i2c->gpio_state)) { dev_err(&pdev->dev, "no gpio pinctrl state\n"); return PTR_ERR(i2c->gpio_state); } pinctrl_select_state(i2c->dev->pins->p, i2c->gpio_state); gpio_direction_input(i2c->sda_gpio); gpio_direction_input(i2c->scl_gpio); pinctrl_select_state(i2c->dev->pins->p, i2c->dev->pins->default_state); // ... }

首先是調用 of_get_gpio 取出設備樹中 i2c1 結點的 gpios 屬于所定義的兩個 gpio:

gpios = <&gpio0 GPIO_A3 GPIO_ACTIVE_LOW>, <&gpio0 GPIO_A2 GPIO_ACTIVE_LOW>;

然后是調用 devm_gpio_request 來申請 gpio,接著是調用 pinctrl_lookup_state 來查找 “gpio” 狀態,而默認狀態 “default” 已經由框架保存到 i2c->dev-pins->default_state 中了。最后調用 pinctrl_select_state 來選擇是 “default” 還是 “gpio” 功能。 下面是常用的復用 API 定義:

#include struct device { //... #ifdef CONFIG_PINCTRL struct dev_pin_info *pins;#endif//...}; struct dev_pin_info {struct pinctrl *p; struct pinctrl_state *default_state; #ifdef CONFIG_PMstruct pinctrl_state *sleep_state; struct pinctrl_state *idle_state;#endif}; struct pinctrl_state * pinctrl_lookup_state(struct pinctrl *p, const char *name); int pinctrl_select_state(struct pinctrl *p, struct pinctrl_state *s); //... };

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

    關注

    87

    文章

    11304

    瀏覽量

    209524
  • 嵌入式主板
    +關注

    關注

    7

    文章

    6085

    瀏覽量

    35342
  • Firefly
    +關注

    關注

    2

    文章

    538

    瀏覽量

    7046
收藏 人收藏

    評論

    相關推薦

    fireflyAIO-3399C主板GPIO簡介

    GPIO, 全稱 General-Purpose Input/Output(通用輸入輸出),是一種軟件運行期間能夠動態配置和控制的通用引腳。
    的頭像 發表于 12-13 10:15 ?2104次閱讀
    <b class='flag-5'>fireflyAIO-3399C</b><b class='flag-5'>主板</b><b class='flag-5'>GPIO</b><b class='flag-5'>簡介</b>

    fireflyAIO-3288C主板GPIO引腳簡介

    GPIO, 全稱 General-Purpose Input/Output(通用輸入輸出),是一種軟件運行期間能夠動態配置和控制的通用引腳。
    的頭像 發表于 12-16 14:27 ?1833次閱讀
    <b class='flag-5'>fireflyAIO-3288C</b><b class='flag-5'>主板</b><b class='flag-5'>GPIO</b>引腳<b class='flag-5'>簡介</b>

    fireflyAIO-3128C主板方案

    開機異常并循環重啟 可能是電源電流不夠,請使用電壓為12V,電流為 2.5A~3A 的電源。
    的頭像 發表于 12-20 10:28 ?975次閱讀
    <b class='flag-5'>fireflyAIO-3128C</b><b class='flag-5'>主板</b>方案

    微雪電子AIO-3128C主板LED使用簡介

    AIO-3128C 開發板上有 2 個 LED 燈
    的頭像 發表于 12-23 16:17 ?2800次閱讀
    微雪電子AIO-<b class='flag-5'>3128C</b><b class='flag-5'>主板</b>LED使用<b class='flag-5'>簡介</b>

    fireflyAIO-3128C主板I2C使用簡介

    firefly
    的頭像 發表于 12-24 08:47 ?899次閱讀

    fireflyAIO-3128C主板ADC介紹使用

    firefly
    的頭像 發表于 12-24 08:45 ?1501次閱讀
    <b class='flag-5'>fireflyAIO-3128C</b><b class='flag-5'>主板</b>ADC介紹使用

    fireflyAIO-3128C主板簡示

    背面視圖
    的頭像 發表于 12-24 09:02 ?593次閱讀
    <b class='flag-5'>fireflyAIO-3128C</b><b class='flag-5'>主板</b>簡示

    fireflyAIO-3128C主板編譯Android 固件介紹

    編譯 Android 對機器的配置要求較高: 64 位 CPU 16GB 物理內存+交換內存
    的頭像 發表于 12-24 09:04 ?1173次閱讀

    fireflyAIO-3128C主板定制Android固件簡介

    定制 Android 固件 前言 定制 Android 固件,有兩種方法: 改源碼,然后編譯生成固件。 在現有固件的基礎上進行裁剪。 前一種方法,可以從各個層面去定制 Android,自由度大,但對編譯環境和技術要求比較高,。現在介紹后一種方法,分為解包、定制和打包三個階段。主機操作系統為 Linux,采用的工具為開源軟件。 固件格式 統一固件 release_update.img,內含啟動加載器 loader.img 和真正的固件數據 update.img release_update.img |- loader.img `- update.img update.img 是個復合
    的頭像 發表于 12-24 09:07 ?1570次閱讀

    fireflyAIO-3128C主板ADB使用簡介

    adb,全稱 Android Debug Bridge,是 Android 的命令行調試工具,可以完成多種功能,如跟蹤系統日志,上傳下載文件,安裝應用等。
    的頭像 發表于 12-24 09:41 ?1105次閱讀

    fireflyAIO-3128C主板MaskRom模式簡介

    MaskRom 模式是設備變磚的最后一條防線。強行進入 MaskRom 涉及硬件操作,有一定風險,因此僅在設備進入不了 Loader 模式的情況下,方可嘗試 MaskRom 模式。
    的頭像 發表于 12-24 09:39 ?1572次閱讀
    <b class='flag-5'>fireflyAIO-3128C</b><b class='flag-5'>主板</b>MaskRom模式<b class='flag-5'>簡介</b>

    fireflyAIO-3128C主板升級固件介紹

    本文介紹了如何將主機上的固件文件,通過雙公頭USB數據線,燒錄到開發板的閃存中。
    的頭像 發表于 12-24 09:30 ?1437次閱讀

    fireflyAIO-3128C主板啟動模式介紹

    AIO-3128C 有靈活的啟動方式。一般情況下,除非硬件損壞,AIO-3128C 開發板是不會變磚的。
    的頭像 發表于 12-24 09:44 ?865次閱讀

    fireflyAIO-3128C主板串口調試介紹

    AIO-3128C 開發板的調試串口與 TF 卡接口有信號引腳復用,因此無法同時使用,即: 使用調試串口時必須拔掉 TF 卡,而使用 TF 卡時不要連接調試串口。
    的頭像 發表于 12-24 09:50 ?1461次閱讀
    <b class='flag-5'>fireflyAIO-3128C</b><b class='flag-5'>主板</b>串口調試介紹

    fireflyAIO-3399J主板GPIO使用簡介

    GPIO, 全稱 General-Purpose Input/Output(通用輸入輸出),是一種軟件運行期間能夠動態配置和控制的通用引腳。
    的頭像 發表于 12-24 11:00 ?2798次閱讀
    <b class='flag-5'>fireflyAIO</b>-3399J<b class='flag-5'>主板</b><b class='flag-5'>GPIO</b>使用<b class='flag-5'>簡介</b>
    主站蜘蛛池模板: 天堂网www在线| 国外免费精品视频在线观看| www.亚洲天堂.com| 黄 色 成 年人在线| 黄色大片在线视频| 性欧美护士18xxxxhd视频| 亚洲mv在线观看| 国内一级毛片| 国产综合13p| 在线观看免费国产| 激情综合五月亚洲婷婷| 激情综合激情| 长腿丝袜美女被啪啪| 久久精品视频5| 97色涩| 色网站观看| 九月婷婷综合婷婷| 伦理片日本韩国电影三级在线观看| 午夜精品一区二区三区在线观看| xxxxx日本69| 欧美婷婷| 免费视频网站在线观看| 中文天堂| ww欧洲ww在线视频免费观看| 好黄好猛好爽好痛的视频| 日韩精品一区二区三区免费视频 | 欧美一级欧美三级| 天堂中文最新版www| 国产高清在线观看| 国产卡一卡2卡三卡免费视频| 亚洲乱码尤物193yw在线播放| 色婷婷成人| 天天操天天操天天| 曰曰摸天天摸人人看久久久 | japan日韩xxxx69hd| 日本5级床片全免费| 欧美seav在线| 午夜免费福利片| 午夜国产片| 亚洲综合亚洲综合网成人| 成人mv高清在线|