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

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

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

AT32講堂029 | AT32F421 GPIO使用指南

雅特力 AT32 MCU ? 2022-10-09 10:01 ? 次閱讀

GPIO特性

最大封裝(48pin)具有39個(gè)多功能雙向的I/O口

所有I/O口都可以映射到16個(gè)外部中斷

幾乎所有I/O口可容忍5V輸入信號(hào)(4個(gè)LEXT / HEXT引腳除外)

所有I/O口均為快速I/O,寄存器存取速度最高fAHB

I/O引腳的外設(shè)功能可以通過(guò)一個(gè)特定的操作鎖定,以避免意外的寫入I/O寄存器

每個(gè)GPIO引腳都可以由軟件配置成輸出(推挽或開漏)、輸入(帶或不帶上拉或下拉)或復(fù)用的外設(shè)功能端口

可選的每個(gè)I/O口的電流推動(dòng)/吸入能力

GPIO設(shè)置/清除寄存器(GPIOx_SCR)和GPIO清除寄存器(GPIOx_CLR)為GPIOx_ODT寄存器提供位訪問(wèn)能力

GPIO

GPIO在復(fù)位期間和剛復(fù)位后,復(fù)用功能未開啟,大部分I/O端口被配置成浮空輸入模式。

當(dāng)作為輸出配置時(shí),寫到輸出數(shù)據(jù)寄存器(GPIOx_ODT)上的值會(huì)輸出到相應(yīng)的I/O引腳??梢砸酝仆炷J交蜷_漏模式(僅低電平被驅(qū)動(dòng),高電平表現(xiàn)為高阻)使用輸出驅(qū)動(dòng)器

輸入數(shù)據(jù)寄存器(GPIOx_IDT)在每個(gè)AHB時(shí)鐘周期捕捉I/O引腳上的數(shù)據(jù)。

所有GPIO引腳有一個(gè)內(nèi)部弱上拉和弱下拉,它們被激活或斷開有賴于GPIOx_PULL寄存器的值。

圖1. GPIO基本結(jié)構(gòu)

ffb073f4-4701-11ed-b116-dac502259ad0.png

表1. GPIO 配置表

ffee6c9a-4701-11ed-b116-dac502259ad0.png

GPIO toggle

AT32F421提供的I/O口均為快速I/O,寄存器存取速度最高為fAHB,所以可以看到GPIO翻轉(zhuǎn)頻率能夠輕松達(dá)到60MHz:

圖2. I/O翻轉(zhuǎn)速度

003fe214-4702-11ed-b116-dac502259ad0.png

IO引腳的5V or 3.3V容忍

標(biāo)準(zhǔn)3.3V容忍引腳(TC)

所有振蕩器用到的引腳都是標(biāo)準(zhǔn)3.3V容忍引腳。

  • PC14/PC15 (HEXT_IN/ OUT)
  • PF0/PF1 (LEXT_IN/ OUT)

表2. TC引腳示例00d3c68c-4702-11ed-b116-dac502259ad0.png

模擬功能5 V容忍引腳(FTa)

比較器輸入引腳以及ADC占用端口為帶模擬功能5 V容忍引腳。

  • PA0 – PA7
  • PB0 – PB2,PB12 – PB15
  • FTa引腳設(shè)置為輸入浮空、輸入上拉、或輸入下拉時(shí),具有5V電平容忍特性;設(shè)置為模擬模式時(shí),不具5V電平容忍特性,此時(shí)輸入電平必須小于VDD + 0.3V

表3. FTa引腳示例00ea2062-4702-11ed-b116-dac502259ad0.png

5V容忍引腳(FT)

其余的GPIO都為5V容忍引腳。表4. FT引腳示例0116e0e8-4702-11ed-b116-dac502259ad0.png

IOMUX

I/O復(fù)用功能輸入/輸出

  • 大多數(shù)外設(shè)共享同一個(gè)GPIO引腳(比如PA0,可作為TMR1_EXT / USART2_CTS /I2C2_SCL / CMP_OUT)
  • 而對(duì)某個(gè)具體的GPIO引腳,在任意時(shí)刻只有一個(gè)外設(shè)能夠與之相連
  • 某些外設(shè)功能還可以重映射到其他引腳,從而使得能同時(shí)使用的外設(shè)數(shù)量更多

選擇每個(gè)端口線的有效復(fù)用功能之一是由兩個(gè)寄存器來(lái)決定的,分別是GPIOx_MUXL和GPIOx_MUXH復(fù)用功能寄存器??筛鶕?jù)應(yīng)用的需求用這兩寄存器連接復(fù)用功能模塊到其他引腳。

表5. 通過(guò)GPIOA_MUX*寄存器配置端口A的復(fù)用功能

0137968a-4702-11ed-b116-dac502259ad0.png

表6. 通過(guò)GPIOB_MUX*寄存器配置端口B的復(fù)用功能

01b30522-4702-11ed-b116-dac502259ad0.png

表7. 通過(guò)GPIOF_MUX*寄存器配置端口F的復(fù)用功能

0213e93c-4702-11ed-b116-dac502259ad0.png

特殊I/O

調(diào)試復(fù)用引腳

  • 在復(fù)位時(shí),和復(fù)位后不像其他GPIO一樣處于浮空輸入狀態(tài),而是處于復(fù)用模式
  • PA13:SWDIO,復(fù)用上拉
  • PA14:SWCLK,復(fù)用下拉

振蕩器復(fù)用引腳

  • 振蕩器關(guān)閉的狀態(tài)下(復(fù)位后的默認(rèn)狀態(tài)),相關(guān)引腳可用作GPIO
  • 振蕩器使能狀態(tài)下,相應(yīng)引腳的GPIO配置無(wú)效
  • 振蕩器處于bypass模式(使用外部時(shí)鐘源)時(shí),LEXT_IN/HEXT_IN為振蕩器時(shí)鐘輸入引腳,LEXT_OUT/HEXT_OUT可做GPIO使用

備份域引腳

當(dāng)1.2V區(qū)域斷電(當(dāng)器件進(jìn)入待機(jī)模式)時(shí),PC13/PC14/PC15失去GPIO功能。在這種情況下,若GPIO配置沒有被RTC配置為bypass,則這些引腳被設(shè)為模擬輸入模式。

  • 以下內(nèi)容在F421系列不存在:模擬開關(guān)(power switch)只能通過(guò)少量的電流(3mA),在輸出模式下使用PC13/PC14/PC15的I/O口功能是有限制的:只能工作在適中電流推動(dòng)/吸入能力模式下,最大負(fù)載為30pF,而且這些I/O口絕對(duì)不能當(dāng)作電流源(如驅(qū)動(dòng)LED)。

GPIO固件驅(qū)動(dòng)程序API

Artery提供的固件驅(qū)動(dòng)程序包含了一系列固件函數(shù)來(lái)管理GPIO的下列功能:

  • 初始化配置
  • 讀取輸入端口或某個(gè)輸入引腳
  • 讀取輸出端口或某個(gè)輸出引腳
  • 設(shè)置或清除某個(gè)引腳的輸出
  • 鎖定引腳
  • 引腳的復(fù)用功能配置

注:所有project都是基于keil 5而建立,若用戶需要在其他編譯環(huán)境上使用,請(qǐng)參考AT32xxx_Firmware_Library_V2.x.x\project\at_start_xxx\templates中各種編譯環(huán)境(例如IAR6/7,keil 4/5)進(jìn)行簡(jiǎn)單修改即可。

輸出模式

GPIO提供了兩種不同類型的輸出模式分別是,推挽輸出以及開漏輸出,下面是輸出模式的配置示例:023d61ae-4702-11ed-b116-dac502259ad0.png

輸入模式

GPIO提供了三種不同類型的輸入模式分別是,浮空輸入、上拉輸入以及下拉輸入,下面是輸入模式的配置示例:026427d0-4702-11ed-b116-dac502259ad0.png

模擬模式

當(dāng)需要使用ADC或CMP通道作為輸入時(shí),需要將相應(yīng)的引腳配置為模擬模式,下面是模擬模式的配置示例:028cac5a-4702-11ed-b116-dac502259ad0.png

復(fù)用模式

1. 不論使用何種外設(shè)模式,都必須將I/O配置為復(fù)用功能,之后系統(tǒng)才能正確使用I/O(輸入或輸出)。

2. I/O引腳通過(guò)復(fù)用器連接到相應(yīng)的外設(shè),該復(fù)用器一次只允許一個(gè)外設(shè)的復(fù)用功能(MUX)連接到I/O引腳。這樣便可確保共用同一個(gè)I/O引腳的外設(shè)之間不會(huì)發(fā)生沖突。每個(gè)I/O引腳都有一個(gè)復(fù)用器,該復(fù)用器具有16路復(fù)用功能輸入/輸出(MUX0到MUX15),可通過(guò)gpio_pin_mux_config()函數(shù)對(duì)這些引腳進(jìn)行配置:

— 復(fù)位后,所有I/O都會(huì)連接到系統(tǒng)的復(fù)用功能0(MUX0)— 通過(guò)配置MUX1到MUX7可以映射外設(shè)的復(fù)用功能

3. 除了這種靈活的I/O復(fù)用架構(gòu)之外,各外設(shè)還具有映射到不同I/O引腳的復(fù)用功能,這可以針對(duì)不同器件封裝優(yōu)化外設(shè)I/O功能的數(shù)量;例如,可將USART2_TX引腳映射到PA2或PA14引腳上。

4. 配置過(guò)程:

— 使用gpio_pin_mux_config()函數(shù)將引腳連接到所需的外設(shè)復(fù)用功能(MUX),例如配置PA0作為TMR1_EXT輸入gpio_pin_mux_config(GPIOA, GPIO_PINS_SOURCE0, GPIO_MUX_4);— 使用GPIO_Init()函數(shù)配置I/O引腳:- 通過(guò)以下方式配置復(fù)用功能模式下的所需引腳gpio_init_struct.gpio_mode = GPIO_MODE_MUX;- 通過(guò)以下成員選擇類型、上拉/下拉和驅(qū)動(dòng)力gpio_out_type、gpio_pull和gpio_drive_strength成員根據(jù)上述配置過(guò)程,下面將介紹幾種外設(shè)的常用配置示例。

USARTI/O復(fù)用模式配置

02ab0f88-4702-11ed-b116-dac502259ad0.png

TMR I/O復(fù)用模式配置

02fd446a-4702-11ed-b116-dac502259ad0.png

I2C I/O復(fù)用模式配置

03271db2-4702-11ed-b116-dac502259ad0.png關(guān)于雅特力雅特力科技于2016年成立,是一家致力于推動(dòng)全球市場(chǎng)32位微控制器(MCU)創(chuàng)新趨勢(shì)的芯片設(shè)計(jì)公司,專注于ARM Cortex-M4/M0+的32位微控制器研發(fā)與創(chuàng)新,全系列采用55nm先進(jìn)工藝及ARM Cortex-M4高效能或M0+低功耗內(nèi)核,締造M4業(yè)界最高主頻288MHz運(yùn)算效能,并支持工業(yè)級(jí)別芯片工作溫度范圍(-40°~105°)。雅特力目前已累積相當(dāng)多元的終端產(chǎn)品成功案例:如微型打印機(jī)、掃地機(jī)、光流無(wú)人機(jī)、熱成像儀、激光雷達(dá)、工業(yè)縫紉機(jī)、伺服驅(qū)控、電競(jìng)周邊市場(chǎng)、斷路器、ADAS、T-BOX、數(shù)字電源、電動(dòng)工具等終端設(shè)備應(yīng)用,廣泛地覆蓋5G、物聯(lián)網(wǎng)、消費(fèi)、商務(wù)及工控等領(lǐng)域。

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

    關(guān)注

    1

    文章

    110

    瀏覽量

    2046
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    AT32F425入門使用指南

    電子發(fā)燒友網(wǎng)站提供《AT32F425入門使用指南.pdf》資料免費(fèi)下載
    發(fā)表于 12-18 11:14 ?6次下載
    AT32<b class='flag-5'>F</b>425入門<b class='flag-5'>使用指南</b>

    AT32F435 & AT32F437入門使用指南

    電子發(fā)燒友網(wǎng)站提供《AT32F435 & AT32F437入門使用指南.pdf》資料免費(fèi)下載
    發(fā)表于 12-18 11:13 ?1次下載
    AT32<b class='flag-5'>F</b>435 & AT32<b class='flag-5'>F</b>437入門<b class='flag-5'>使用指南</b>

    AT32F425入門使用指南

    AT32F425入門使用指南旨在讓用戶快速使用AT32F425xx 進(jìn)行項(xiàng)目開發(fā)。
    發(fā)表于 10-26 07:46

    AT32 VSCode PlatFormIO使用指南

    AT32 VSCode PlatFormIO使用指南旨在幫助使用VSCode+PlatFormIO開發(fā)AT32的用戶,快速建立開發(fā)環(huán)境并進(jìn)行開發(fā)。
    發(fā)表于 10-26 07:14

    AT32F415 AT32F421 ERTC時(shí)間戳的使用

    AT32F415 AT32F421 ERTC 時(shí)間戳的使用演示AT32F415以及AT32F421 ERTC時(shí)間戳的使用。
    發(fā)表于 10-26 06:01

    AT32F413/415 GPIO使用指南

    AT32F413/415 GPIO使用指南介紹AT32F413/415 的GPIO 功能及固件驅(qū)動(dòng)程序API 的配置和使用,并對(duì)BSP 例程
    發(fā)表于 10-25 08:24

    AT32 MCU ACC使用指南

    AT32 MCU ACC使用指南AT32 MCU 擁有HICK 自動(dòng)時(shí)鐘校準(zhǔn)器,其作用是當(dāng)系統(tǒng)內(nèi)部使用HICK 作為時(shí)鐘源時(shí),若外界環(huán)境改變等因素導(dǎo)致HICK 時(shí)鐘差生偏差時(shí),可利用HICK 自動(dòng)時(shí)鐘校準(zhǔn)器將HICK 校準(zhǔn)到合理
    發(fā)表于 10-25 07:24

    AT32F421 ADC使用指南

    AT32 的 ADC 是一個(gè)將模擬輸入信號(hào)轉(zhuǎn)換為設(shè)定分辨率數(shù)位數(shù)字信號(hào)的外設(shè)。采樣率最高可達(dá)2MSPS。多達(dá) 18 個(gè)通道源可進(jìn)行采樣及轉(zhuǎn)換。具備多種功能強(qiáng)大的模式,本文主要以 ADC 的特色功能進(jìn)行講解和案列解析。
    發(fā)表于 10-25 06:42

    AT32外部中斷/事件EXINT使用指南

    AT32外部中斷/事件EXINT使用指南介紹AT32 系列MCU 的EXINT 功能及其固件驅(qū)動(dòng)程序API,并對(duì)BSP 例程的軟件設(shè)計(jì)加以說(shuō)明,同時(shí)演示使用方法并展示實(shí)驗(yàn)效果,供用戶參考。
    發(fā)表于 10-25 06:25

    AT32F421時(shí)鐘配置

    AT32F421時(shí)鐘配置本應(yīng)用入門指南主要介紹兩部分內(nèi)容:1、基于雅特力提供的V2.x.x 的板級(jí)支持包來(lái)進(jìn)行時(shí)鐘源碼的配置及修改2、如何使用配套的時(shí)鐘配置工具來(lái)進(jìn)行時(shí)鐘路徑及參數(shù)的設(shè)定,生成相應(yīng)的時(shí)鐘流程代碼并使用。
    發(fā)表于 10-25 06:04

    AT32F421 CMP使用指南

    AT32F421 CMP 使用指南描述了怎么使用AT32F421xx的比較器(CMP)。AT32F421系列內(nèi)置一個(gè)超低功耗比較器CMP,它可用作獨(dú)立器件(I/O上提供了全部接口),也
    發(fā)表于 10-24 08:07

    AT32F421 GPIO使用指南

    AT32F421 GPIO 使用指南AT32F421系列的GPIO還提供了豐富I/O復(fù)用功能,能夠使得多個(gè)外設(shè)可以同時(shí)工作,并且保證每個(gè)引腳
    發(fā)表于 10-24 07:53

    AT32F421入門使用指南

    AT32F421入門使用指南旨在讓用戶快速使用AT32F421xx 進(jìn)行項(xiàng)目開發(fā)。
    發(fā)表于 10-24 07:38

    AT32F421系列安全庫(kù)區(qū)的應(yīng)用原理、軟件使用方法及范例程序

    AT32F421 Security Library Application Note主要在闡述AT32F421系列安全庫(kù)區(qū)的應(yīng)用原理、軟件使用方法及范例程序。
    發(fā)表于 10-24 07:00

    AT32_IEC 60730_CLASSB軟件庫(kù)使用指南

    AT32_IEC 60730_CLASSB軟件庫(kù)使用指南描述了AT32系列的MCU如何執(zhí)行IEC 60730中所要求的軟件安全性相關(guān)的操作。
    發(fā)表于 10-24 06:40