女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

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

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

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

如何在STM8微控制器上使用GPIO

454398 ? 來源:工程師吳畏 ? 2019-07-31 09:18 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

原理圖

如何在STM8微控制器上使用GPIO

通用設(shè)計

使用PIC和AVR器件時,您通常需要獲取該特定器件的數(shù)據(jù)表,并了解如何使用外設(shè)。有時,一個PIC上的外設(shè)可能與另一個PIC上的外設(shè)不同,因此不能簡單地將代碼從一個PIC復(fù)制并粘貼到另一個PIC。但是,STM8完全不同,因為所有STM8設(shè)備都使用通用布局而不是具有唯一配置。這意味著為一個STM8設(shè)計的代碼可以直接復(fù)制并粘貼到不同的控制器,它仍然可以工作(假設(shè)新設(shè)備具有所需的外設(shè))。

一個典型的例子是UART外設(shè)。 STM8器件最多可以有三個UART端口(1,2和3),一個STM8器件上的UART1與另一個STM8器件上的UART1相同。但是,各個STM8器件的數(shù)據(jù)表中沒有太多關(guān)于如何使用外設(shè)的信息,因此在使用任何STM8器件時,您需要使用數(shù)據(jù)表;包含引腳分布的器件專用數(shù)據(jù)表,以及包含器件系列細(xì)節(jié)的另一個數(shù)據(jù)表。

對于我們的STM8項目,我們將利用這兩個數(shù)據(jù)表中的信息:

STM8S103F3器件數(shù)據(jù)表(PDF) - 包含基本細(xì)節(jié)和引腳信息

STM8系列器件概述(PDF) - 包含詳細(xì)的外設(shè)和CPU信息

如果您想知道設(shè)備上的引腳位置,請使用設(shè)備數(shù)據(jù)表,如果您想了解如何使用外圍設(shè)備,請使用系列設(shè)備概述表。

GPIO

雖然開發(fā)板允許我們對STM8進(jìn)行編程微控制器和CPU功能,除非我們可以將微型連接到其他設(shè)備和外部電路,否則它是毫無意義的。為了能夠執(zhí)行此類任務(wù),使用通用輸入輸出或GPIO。 GPIO是器件上的引腳,可以電連接到外部電路,以控制它們或從中讀取信息。雖然可以讀取模擬數(shù)據(jù),但本教程僅關(guān)注數(shù)字值(打開或關(guān)閉的數(shù)字值)。

說到GPIO,有四個主要寄存器

DDR - 數(shù)據(jù)方向寄存器

ODR - 輸出數(shù)據(jù)寄存器

IDR - 輸入數(shù)據(jù)寄存器

CR1和CR2 - 控制寄存器

圖片由RM0016參考手冊提供。

訪問寄存器和位

訪問STM8上的GPIO有點類似于AVR ,除了STM8S.h使用結(jié)構(gòu)。例如,STM8S上的PORT B有自己的結(jié)構(gòu),稱為GPIOB,內(nèi)部是控制它的所有寄存器(如DDR,ODR,IDR等)。訪問這些寄存器可以如下所示:

GPIOB→xxx其中xxx是有問題的寄存器

數(shù)據(jù)方向寄存器(DDR)

與PIC和AVR器件一樣,STM8使用數(shù)據(jù)方向寄存器來確定引腳是輸入還是輸出。這些寄存器為8位寬,直接對應(yīng)I/O端口上的引腳。例如,PORT B最多可以有8個引腳,B0對應(yīng)端口B DDR寄存器中的第0位,而B7對應(yīng)端口B DDR寄存器中的第7位。

將引腳配置為輸入時,需要清零相應(yīng)的DDR位(0),對于輸出,需要設(shè)置該位(1)。因此,比方說,我們只想將B0和B1配置為輸入,同時將其余部分保持為輸出。我們可以執(zhí)行以下操作:

GPIOB→DDR = 0xFC;

GPIOB→DDR = 0b11111100;

控制寄存器CR1和CR2

CR1和CR2是控制寄存器,可配置為提供不同的I/O功能。例如,它們可以配置為允許在各個引腳上產(chǎn)生中斷,并可用于創(chuàng)建具有推/拉功能的輸出驅(qū)動器。與其他寄存器一樣,CR1和CR2寄存器中的每個位對應(yīng)一個特定的引腳。因此,例如,CR1和CR2中的位0用于端口的引腳0。下表(摘自數(shù)據(jù)表)演示了CR1和CR2寄存器的用途。

輸出數(shù)據(jù)寄存器( ODR)

輸出數(shù)據(jù)寄存器用于輸出數(shù)字值(1和0)到一個端口。可以寫入各個位(使用位掩碼),也可以更改整個寄存器。將1位寫入ODR位將使相應(yīng)的引腳導(dǎo)通,寫入0將使相應(yīng)的引腳關(guān)閉。下面的第一個示例用于打開端口上的所有引腳,第二個示例關(guān)閉所有引腳。

GPIOB→ODR = 0xFF;或GPIOB→ODR = 0b11111111;//打開所有引腳

GPIOB→ODR = 0x00;或GPIOB→ODR = 0b00000000;//關(guān)閉所有引腳

輸入數(shù)據(jù)寄存器(IDR)

IDR寄存器可用于讀取端口引腳上的數(shù)字值。這些值可以是(1)或關(guān)閉(0),IDR寄存器的第0位對應(yīng)引腳0,而第7位對應(yīng)引腳7.

pinRead = GPIOB→IDR;

有用的位操作

因為我/O端口由各個引腳組成,與整個寄存器相比,訪問個別位更有幫助。但是,個別位不可用(類似于AVR設(shè)備),因此我們需要使用一些位操作。由于這已經(jīng)在AVR系列中進(jìn)行了解釋,我們只會看一些非常有用的宏。

這些非常有用的宏有助于擺脫不可讀的位掩碼:

#define setBit(reg,bit)(reg = reg |(1 《

#define clearBit(reg,bit)(reg = reg&?(1 《

#define toggleBit(reg,bit)(reg = reg ^(1 《

將此代碼復(fù)制并粘貼到代碼頂部,然后,您可以像函數(shù)一樣使用它們,而不必編寫位操作代碼。那么讓我們看一些如何在代碼中使用它們的示例!

setBit(GPIOB→DDR,3);//將端口B上的第3位設(shè)置為輸出

clearBit(GPIOA→ODR,4);//關(guān)閉端口a上的輸出位4

toggleBit(GPIOC→ODR) ,5);//在端口c上切換第5位

然而,讀取引腳使用一個簡單的位操作,包括使用AND來屏蔽我們不需要的所有位,然后測試查看結(jié)果是否為0。

if( (GPIOB→IDR & 0b00000001) )

{

// Code here executes IF bit 0 is on

}

if( !(GPIOB→IDR & 0b00000001) )

{

// Code here executes IF bit 0 is off

}

基本配置示例

在本例中,我們將引腳A1配置為輸入,B5配置為輸出,每當(dāng)按下開關(guān)(連接到A1)時,LED連接到B5將切換。這里我們也利用內(nèi)部上拉,因此我們的按鈕不需要上拉電阻工作(通過設(shè)置CR1中的位來完成)。

/* MAIN.C file

*

* Copyright (c) 2002-2005 STMicroelectronics

*/

#include “stm8s.h”

#define setBit(reg, bit) (reg = reg | (1 《《 bit))

#define clearBit(reg, bit) (reg = reg & ~(1 《《 bit))

#define toggleBit(reg, bit) (reg = reg ^ (1 《《 bit))

void simpleDelay(void);

main()

{

GPIOA-》DDR = 0x00; // Make all pins on PORT A inputs

GPIOA-》CR1 = 0xFF; // Ensure that internal pull up is on

GPIOA-》CR2 = 0x00; // Ensure that interrupts are turned off

GPIOB-》DDR = 0xFF;

while (1)

{

// Testing bit 1 (bit 0 would be 1)

if( ?。℅PIOA-》IDR & 0x02) )

{

toggleBit(GPIOB-》ODR, 5);

simpleDelay();

}

}

}

// Simple delay used for debouncing

void simpleDelay(void)

{

unsigned int i, j;

for(i = 0; i 《 1000; i ++)

{

for(j=0; j 《 10; j ++)

{

}

}

}

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

    關(guān)注

    18

    文章

    392

    瀏覽量

    57834
  • GPIO
    +關(guān)注

    關(guān)注

    16

    文章

    1280

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

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

    何在MCXN947微控制器配置安全啟動和生命周期

    本文檔旨在介紹如何在MCXN947微控制器配置安全啟動和生命周期,以確保產(chǎn)品在量產(chǎn)階段的安全性,防止代碼被竊取和篡改,并且能夠安全地升級更新固件。通過本應(yīng)用筆記,開發(fā)者可以更好地理解和實施安全啟動和固件更新的最佳實踐。
    的頭像 發(fā)表于 06-26 09:49 ?1072次閱讀
    如<b class='flag-5'>何在</b>MCXN947<b class='flag-5'>微控制器</b><b class='flag-5'>上</b>配置安全啟動和生命周期

    8微控制器KF8A100Fxx數(shù)據(jù)手冊

    電子發(fā)燒友網(wǎng)站提供《8微控制器KF8A100Fxx數(shù)據(jù)手冊.pdf》資料免費(fèi)下載
    發(fā)表于 05-30 16:11 ?0次下載

    CY8C40xx系列32 位 PSOC? Arm? Cortex? 微控制器Cypress

    CY8C40xx系列32 位 PSOC? Arm? Cortex? 微控制器CypressPSoC 4是Cypress微控制器的可擴(kuò)展可重構(gòu)系統(tǒng)架構(gòu),涵蓋了Arm CortexTM-M0CPU
    發(fā)表于 01-17 09:14

    GPIO錯誤排查與解決

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

    如何配置GPIO引腳

    引腳是微控制器的一個多功能接口,可以被配置為數(shù)字輸入、數(shù)字輸出、模擬輸入/輸出或特殊功能。在數(shù)字模式下,GPIO引腳可以是高電平(邏輯1)或低電平(邏輯0)。在模擬模式下,它們可以讀取模擬信號。 配置
    的頭像 發(fā)表于 01-09 09:39 ?1221次閱讀

    何在i.MX RT微控制器初始化LWIP協(xié)議棧

    在i.MX RT微控制器初始化LWIP協(xié)議棧是一個復(fù)雜但有趣的過程,它涉及多個步驟和關(guān)鍵組件的配置.
    的頭像 發(fā)表于 10-12 11:48 ?820次閱讀
    如<b class='flag-5'>何在</b>i.MX RT<b class='flag-5'>微控制器</b><b class='flag-5'>上</b>初始化LWIP協(xié)議棧

    調(diào)試MSP430系列微控制器的閃存問題

    電子發(fā)燒友網(wǎng)站提供《調(diào)試MSP430系列微控制器的閃存問題.pdf》資料免費(fèi)下載
    發(fā)表于 10-09 10:27 ?0次下載
    調(diào)試MSP430系列<b class='flag-5'>微控制器</b><b class='flag-5'>上</b>的閃存問題

    增加微控制器的輸入數(shù)

    電子發(fā)燒友網(wǎng)站提供《增加微控制器的輸入數(shù).pdf》資料免費(fèi)下載
    發(fā)表于 09-21 10:30 ?0次下載
    增加<b class='flag-5'>微控制器</b><b class='flag-5'>上</b>的輸入數(shù)

    什么是微控制器/它的關(guān)鍵組成部分有哪些?

    微控制器
    芯廣場
    發(fā)布于 :2024年09月18日 15:02:33

    增加微控制器的輸入數(shù)量產(chǎn)品概述

    電子發(fā)燒友網(wǎng)站提供《增加微控制器的輸入數(shù)量產(chǎn)品概述.pdf》資料免費(fèi)下載
    發(fā)表于 09-13 09:08 ?0次下載
    增加<b class='flag-5'>微控制器</b><b class='flag-5'>上</b>的輸入數(shù)量產(chǎn)品概述

    微控制器內(nèi)部的存儲有哪些

    微控制器(MCU)內(nèi)部的存儲微控制器系統(tǒng)的重要組成部分,它負(fù)責(zé)存儲程序代碼、數(shù)據(jù)以及控制邏輯等信息。這些存儲類型多樣,各具特點,共同支
    的頭像 發(fā)表于 08-22 10:41 ?1457次閱讀

    微控制器的結(jié)構(gòu)和應(yīng)用

    微控制器(Microcontroller Unit,簡稱MCU)作為嵌入式系統(tǒng)的核心部件,其原理和應(yīng)用在現(xiàn)代科技發(fā)展中占據(jù)了舉足輕重的地位。本文將從微控制器的原理、基本結(jié)構(gòu)、工作原理、性能特點以及廣泛的應(yīng)用領(lǐng)域等方面進(jìn)行詳細(xì)闡述,旨在全面介紹
    的頭像 發(fā)表于 08-22 10:40 ?2581次閱讀

    何在RL78微控制器使用EZ-CUBE3

    本章描述了如何使用EZ-CUBE3在RL78微控制器上進(jìn)行片上調(diào)試和Flash編程。
    的頭像 發(fā)表于 08-01 16:01 ?1512次閱讀
    如<b class='flag-5'>何在</b>RL78<b class='flag-5'>微控制器</b><b class='flag-5'>上</b>使用EZ-CUBE3

    何在Android 10設(shè)備通過App控制GPIO

    本文檔提供了在 Android 10 設(shè)備通過應(yīng)用程序(App)控制通用輸入輸出(GPIO)的詳細(xì)指南。這涵蓋了從創(chuàng)建 gpio驅(qū)動到App 配置 以及 SELinux 策略以允許特
    的頭像 發(fā)表于 07-22 17:59 ?2010次閱讀

    STM32 GPIO八種模式及工作原理詳解

    一. 前言 ??GPIO全稱General Purpose Input Output,是微控制數(shù)字輸入/輸出的基本模塊,可以實現(xiàn)微控制器與外部環(huán)境的數(shù)字進(jìn)行交換。借助GPIO
    的頭像 發(fā)表于 07-22 09:32 ?8846次閱讀
    STM32 <b class='flag-5'>GPIO</b>八種模式及工作原理詳解