chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

全面掌握stm32的GPIO知識

硬件攻城獅 ? 來源:技術(shù)讓夢想更偉大 ? 作者:技術(shù)讓夢想更偉大 ? 2022-11-02 12:47 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1 初學(xué)者重要提示

本文主要是以stm32H7系列為主。

對于不使用的引腳,推薦設(shè)置為模擬模式,懸空即可。

GPIO的速度等級高的時(shí)候,最好使能IO補(bǔ)償單元。

2 GPIO功能簡介

STM32H7的GPIO特性如下:

輸出狀態(tài):開漏/推挽 + 上拉/下拉電阻。

通過輸出數(shù)據(jù)寄存器(GPIOx_ODR)或者外設(shè)(GPIO設(shè)置為復(fù)用模式時(shí))輸出數(shù)據(jù)。

GPIO速度等級設(shè)置。

輸入狀態(tài):浮空,上拉/下拉,模擬。

通過輸入數(shù)據(jù)寄存器(GPIOx_IDR)或者外設(shè)(GPIO設(shè)置為復(fù)用模式)輸入數(shù)據(jù)。

通過寄存器GPIOx_BSRR實(shí)現(xiàn)對寄存器GPIOx_ODR的位操作。

通過配置寄存器GPIOx_LCKR的鎖機(jī)制,實(shí)現(xiàn)凍結(jié)IO口配置。

每兩個(gè)時(shí)鐘周期就可以翻轉(zhuǎn)一次IO。

高度靈活的引腳復(fù)用功能,允許IO引腳既可以做GPIO也可以做功能復(fù)用。

3 GPIO功能模式分析(重要)

STM32H7的GPIO端口可以配置為如下的8種模式:

輸入浮空

輸入上拉

輸入下拉

模擬功能

具有上拉或下拉功能的開漏輸出

具有上拉或下拉功能的推挽輸出

具有上拉或下拉功能的復(fù)用功能推挽

具有上拉或下拉功能的復(fù)用功能開漏

由于上拉和下拉是可選配置,對應(yīng)的HAL庫配置使用下面6種就可以表示:

GPIO_MODE_INPUT 輸入模式

GPIO_MODE_OUTPUT_PP 推挽輸出

GPIO_MODE_OUTPUT_OD 開漏輸出

GPIO_MODE_AF_PP 復(fù)用推挽

GPIO_MODE_AF_OD 復(fù)用開漏

GPIO_MODE_ANALOG 模擬模式

3.1 推挽輸出

5617e5f0-5a68-11ed-a3b6-dac502259ad0.png

推挽電路是兩個(gè)參數(shù)相同的三極管或 MOSFET,以推挽方式存在于電路中。電路工作時(shí),兩只對稱的開關(guān)管每次只有一個(gè)導(dǎo)通,導(dǎo)通損耗小、效率高。輸出既可以向負(fù)載灌電流,也可以從負(fù)載抽取電流。推拉式輸出級提高電路的負(fù)載能力。相對于開漏輸出模式,推挽輸出最大優(yōu)勢是輸出高電平時(shí),上升時(shí)間快,電壓驅(qū)動能力強(qiáng)。

3.2 開漏輸出

562669fe-5a68-11ed-a3b6-dac502259ad0.png

開漏端相當(dāng)于 MOS 管的漏極(三極管的集電極),要得到高電平狀態(tài)必須外接上拉電阻才行,因此輸出高電平的驅(qū)動能力完全由外接上拉電阻決定,但是其輸出低電平的驅(qū)動能力很強(qiáng)。開漏形式的電路有以下幾個(gè)特點(diǎn):

輸出高電平時(shí)利用外部電路的驅(qū)動能力,減少 IC 內(nèi)部的驅(qū)動。

開漏是用來連接不同電平的器件,匹配電平用的,因?yàn)殚_漏引腳不連接外部的上拉電阻時(shí),只能輸出低電平。如果需要同時(shí)具備輸出高電平的功能,則需要接上拉電阻,很好的一個(gè)優(yōu)點(diǎn)是通過改變上拉電源的電壓,便可以改變傳輸電平。上拉電阻的阻值決定了邏輯電平轉(zhuǎn)換的速度。阻值越大,速度越低,功耗越小。

開漏輸出提供了靈活的輸出方式,但是也有其弱點(diǎn),就是帶來上升沿的延時(shí)。因?yàn)樯仙厥峭ㄟ^外接上拉無源電阻對負(fù)載充電,所以當(dāng)電阻選擇小時(shí)延時(shí)就小,但功耗大;反之延時(shí)大功耗小。所以如果對延時(shí)有要求,則建議用下降沿輸出。

可以將多個(gè)開漏輸出連接到一條線上。通過一只上拉電阻,在不增加任何器件的情況下,形成“與邏輯”關(guān)系,即“線與”??梢院唵蔚睦斫鉃椋涸谒幸_連在一起時(shí),外接一上拉電阻,如果有一個(gè)引腳輸出為邏輯 0,相當(dāng)于接地,與之并聯(lián)的回路“相當(dāng)于被一根導(dǎo)線短路”,所以外電路邏輯電平便為 0,只有都為高電平時(shí),與的結(jié)果才為邏輯 1。

3.3 復(fù)用推挽和開漏

復(fù)用指的是GPIO切換到CPU內(nèi)部設(shè)備(比如SPI,I2C,UART等電路),也就是GPIO不是作為普通IO使用,是由內(nèi)部設(shè)備直接驅(qū)動。推挽和開漏的特征同上。

3.4 四種輸入模式

5630a144-5a68-11ed-a3b6-dac502259ad0.png

通過上面的引腳結(jié)構(gòu)圖可以得到如下三種方式

浮空輸入:CPU內(nèi)部的上拉電阻、下拉電阻均斷開的輸入模式。

下拉輸入:CPU內(nèi)部的下拉電阻使能、上拉電阻斷開的輸入模式。

上拉輸入:CPU內(nèi)部的上拉電阻使能、下拉電阻斷開的輸入模式。

而模擬輸入模式是GPIO引腳連接內(nèi)部ADC。

563ab300-5a68-11ed-a3b6-dac502259ad0.png

4 GPIO的拉電流負(fù)載和灌電流負(fù)載能力

這里先普及點(diǎn)小知識,什么是拉電流負(fù)載,什么是灌電流負(fù)載。

拉電流負(fù)載:一種負(fù)載電流從驅(qū)動門流向外電路,稱為拉電流負(fù)載。比如使用STM32H7的GPIO直接驅(qū)動LED就是拉電流形式。

5642a376-5a68-11ed-a3b6-dac502259ad0.png

灌電流負(fù)載:負(fù)載電流從外電路流入驅(qū)動門,稱為灌電流負(fù)載。比如下面這種形式的LED驅(qū)動電路

564de420-5a68-11ed-a3b6-dac502259ad0.png

有了上面這些知識后再來看STM32H7的IO驅(qū)動能力(截圖來自STM32H7參考手冊):

5658c142-5a68-11ed-a3b6-dac502259ad0.png

通過上面的截圖可知:STM32H7總的拉電流和灌電流不可超過140mA,單個(gè)引腳最大不可超過20mA,這個(gè)知識點(diǎn),大家要知道。

5 IO補(bǔ)償單元,用于高速

IO補(bǔ)償單元用于控制I/O通信壓擺率(tfall/ trise)以此來降低I/O噪聲。當(dāng)前STM32H7的速度等級可以配置為以下四種:

566b3980-5a68-11ed-a3b6-dac502259ad0.jpg

/** @defgroup GPIO_speed_define  GPIO speed define
  * @brief GPIO Output Maximum frequency
  * @{
  */  
#define  GPIO_SPEED_FREQ_LOW         ((uint32_t)0x00000000U)  /*!< Low speed     */
#define  GPIO_SPEED_FREQ_MEDIUM      ((uint32_t)0x00000001U)  /*!< Medium speed  */
#define  GPIO_SPEED_FREQ_HIGH        ((uint32_t)0x00000002U)  /*!< Fast speed    */
#define  GPIO_SPEED_FREQ_VERY_HIGH   ((uint32_t)0x00000003U)  /*!< High speed    */

566b3980-5a68-11ed-a3b6-dac502259ad0.jpg

使用后兩種速度等級的話,最好使能IO補(bǔ)償單元。

6 GPIO兼容CMOS和TTL電平

CMOS和TTL電平兼容問題也是一個(gè)比較重要的知識點(diǎn)

567dc8b6-5a68-11ed-a3b6-dac502259ad0.png

7 不使用的引腳推薦設(shè)置為模擬模式

主要從功耗和防干擾考慮。

所有用作帶上拉電阻輸入的 I/O都會在引腳外部保持為低時(shí)產(chǎn)生電流消耗。此電流消耗的值可通過使用的靜態(tài)特性中給出的上拉 / 下拉電阻值簡單算出。

對于輸出引腳,還必須考慮任何外部下拉電阻或外部負(fù)載以估計(jì)電流消耗。

若外部施加了中間電平,則額外的 I/O 電流消耗是因?yàn)榕渲脼檩斎氲?I/O。此電流消耗是由用于區(qū)分輸入值的輸入施密特觸發(fā)器電路導(dǎo)致。除非應(yīng)用需要此特定配置,否則可通過將這些I/O 配置為模擬模式以避免此供電電流消耗。ADC 輸入引腳應(yīng)配置為模擬輸入就是這種情況。

任何浮空的輸入引腳都可能由于外部電磁噪聲,成為中間電平或意外切換。為防止浮空引腳相關(guān)的電流消耗,它們必須配置為模擬模式,或內(nèi)部強(qiáng)制為確定的數(shù)字值。這可通過使用上拉 / 下拉電阻或?qū)⒁_配置為輸出模式做到。

綜上考慮,不使用的引腳設(shè)置為模擬模式,懸空即可。

審核編輯 :李倩

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

    關(guān)注

    31

    文章

    5590

    瀏覽量

    129111
  • STM32
    +關(guān)注

    關(guān)注

    2305

    文章

    11124

    瀏覽量

    371248
  • GPIO
    +關(guān)注

    關(guān)注

    16

    文章

    1313

    瀏覽量

    55743

原文標(biāo)題:全面掌握stm32的GPIO,看這篇就可以了!

文章出處:【微信號:mcu168,微信公眾號:硬件攻城獅】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    嵌入式應(yīng)掌握的幾種能力

    框圖、掌握基礎(chǔ)外設(shè)如:GPIO、UART、TIM、ADC、DAC、I2C、SPI的裸機(jī)編程及相關(guān)原理、應(yīng)用。 3. 操作系統(tǒng) 基本掌握操作系統(tǒng)相關(guān)知識。 先了解學(xué)習(xí)RTOS,如
    發(fā)表于 12-08 06:05

    CW32嵌入式軟件開發(fā)的必備知識

    全面的測試,確保軟件功能的正確性和穩(wěn)定性。 了解嵌入式系統(tǒng)的可靠性要求,能夠進(jìn)行軟件的可靠性測試和驗(yàn)證。 只有全面掌握這些知識并具備持續(xù)學(xué)習(xí)的能力,才能成為一名優(yōu)秀的嵌入式軟件開發(fā)人員
    發(fā)表于 11-28 07:48

    GPIO、PWM、ADC,到底怎么區(qū)分?

    在嵌入式開發(fā)中,我們經(jīng)常聽到GPIO、PWM、ADC這些術(shù)語。初學(xué)者常常搞不清楚它們的區(qū)別和用途:“它們不是都是和電平有關(guān)嗎?為什么還要分這么多種?”今天,我們就把這些基礎(chǔ)概念講清楚,讓你在動手開發(fā)
    的頭像 發(fā)表于 11-14 10:28 ?260次閱讀
    <b class='flag-5'>GPIO</b>、PWM、ADC,到底怎么區(qū)分?

    嵌入式需要掌握哪些核心技能?

    系統(tǒng)、外設(shè)驅(qū)動(如GPIO、PWM、ADC)。 實(shí)踐工具:通過STM32開發(fā)板學(xué)習(xí)外設(shè)驅(qū)動開發(fā),結(jié)合電路原理圖理解硬件設(shè)計(jì)。 企業(yè)需求:90%的崗位要求熟悉STM32等MCU,部分崗位涉及GD32
    發(fā)表于 10-21 16:25

    迅為RK3568驅(qū)動指南GPIO子系統(tǒng) GPIO操作函數(shù)實(shí)驗(yàn)

    迅為電子RK3568開發(fā)板驅(qū)動指南GPIO子系統(tǒng) GPIO操作函數(shù)實(shí)驗(yàn)
    的頭像 發(fā)表于 05-28 15:24 ?1065次閱讀
    迅為RK3568驅(qū)動指南<b class='flag-5'>GPIO</b>子系統(tǒng) <b class='flag-5'>GPIO</b>操作函數(shù)實(shí)驗(yàn)

    為什么GPIO配置總是出問題?

    STM32開發(fā)中,GPIO(通用輸入輸出)配置看似簡單,但在實(shí)際開發(fā)中,很多人常常會遇到這些困惑:明明按照教程配置了GPIO,為什么LED燈就是不亮?為什么有時(shí)候按鍵無法響應(yīng),或者響應(yīng)很慢
    的頭像 發(fā)表于 04-07 11:59 ?1390次閱讀
    為什么<b class='flag-5'>GPIO</b>配置總是出問題?

    STM32學(xué)習(xí)GPIO之設(shè)計(jì)篇

    今日分享 GPIO 結(jié)合寄存器以及硬件電路,再來舉例子分析輸入輸出。寄存器介紹:通過寄存器的位標(biāo)注 rw,我們可知這個(gè)寄存器的某個(gè)位是可讀(r)并且可寫 的(w),我們也可以通過讀寄存器里面的值得
    發(fā)表于 03-27 13:57 ?2次下載

    單片機(jī)學(xué)習(xí)之GPIO

    今日分享如何通過手冊理解單片機(jī)IO知識點(diǎn)含義解釋:1.GPIO:同我們常說的IO口一樣,GeneralPurposeInputOutput(通用輸入/輸出)簡稱為GPIO,每個(gè)GPIO
    發(fā)表于 03-26 14:53 ?0次下載

    【北京迅為】iTOP-RK3568OpenHarmony系統(tǒng)南向驅(qū)動開發(fā)GPIO基礎(chǔ)知識

    【北京迅為】iTOP-RK3568OpenHarmony系統(tǒng)南向驅(qū)動開發(fā)GPIO基礎(chǔ)知識
    的頭像 發(fā)表于 03-06 11:23 ?1025次閱讀
    【北京迅為】iTOP-RK3568OpenHarmony系統(tǒng)南向驅(qū)動開發(fā)<b class='flag-5'>GPIO</b>基礎(chǔ)<b class='flag-5'>知識</b>

    嵌入式教育科普|GPIO接口全面解析

    知識掌握直接影響著嵌入式項(xiàng)目實(shí)現(xiàn)功能的成效。本文將以GPIO接口為切入點(diǎn),深入解析其工作原理與技術(shù)特性,希望能幫助屏幕前想要學(xué)習(xí)嵌入式開發(fā)的小伙伴建立嵌入式接口的
    的頭像 發(fā)表于 03-05 11:11 ?2770次閱讀
    嵌入式教育科普|<b class='flag-5'>GPIO</b>接口<b class='flag-5'>全面</b>解析

    GPIO使用教程 GPIO接口應(yīng)用

    GPIO(General-Purpose Input/Output,通用輸入/輸出)接口是電子設(shè)備中的一個(gè)重要組成部分,主要用于控制和讀取設(shè)備的數(shù)字信號。它通過簡單的高(1)或低(0)電平來與系統(tǒng)
    的頭像 發(fā)表于 01-31 10:10 ?5236次閱讀

    GPIO模塊與其他外設(shè)的連接方法

    在嵌入式系統(tǒng)設(shè)計(jì)中,GPIO模塊是實(shí)現(xiàn)設(shè)備與外部世界交互的關(guān)鍵接口。它們提供了一種靈活的方式來控制和監(jiān)測外部設(shè)備。 GPIO模塊的基本概念 GPIO模塊由一組引腳組成,每個(gè)引腳都可以被獨(dú)立地配置為
    的頭像 發(fā)表于 01-09 09:48 ?1511次閱讀

    GPIO錯(cuò)誤排查與解決

    在嵌入式系統(tǒng)和微控制器編程中,通用輸入輸出(GPIO)是最常見的接口之一。然而,在使用GPIO時(shí),我們可能會遇到各種錯(cuò)誤。 1. 理解GPIO GPIO是微控制器上的一組引腳,可以被配
    的頭像 發(fā)表于 01-09 09:46 ?3734次閱讀

    如何配置GPIO引腳

    在嵌入式系統(tǒng)設(shè)計(jì)中,GPIO(通用輸入/輸出)引腳是連接微控制器與外部世界的重要橋梁。它們可以被配置為輸入或輸出模式,用于讀取傳感器數(shù)據(jù)、控制LED燈、驅(qū)動電機(jī)等。 GPIO引腳的基本概念 GPIO
    的頭像 發(fā)表于 01-09 09:39 ?1876次閱讀

    SEGGER工具全面支持STM32N6微控制器開發(fā)

    2024年12月,SEGGER宣布全面支持ST首款帶有神經(jīng)處理單元(NPU)的微控制器STM32N6。
    的頭像 發(fā)表于 12-18 11:05 ?1157次閱讀