STM32 GPIO口的使用

发布者:快乐心跳最新更新时间:2017-10-26 来源: eefocus关键字:STM32  GPIO口 手机看文章 扫描二维码
随时随地手机看文章

实验平台清单如下:

开发板:              战舰 STM32ZET6 V3.4

核心芯片:          STM32F103RCT6

开发环境:          MDK-ARM Version:5.10

PC操作系统:     Windows 7 旗舰版

仿真器:             ST-Link

打开MDK开发平台,在菜单栏中单击“Project - New μVision Project”创建一个新的工程。然后在弹出的“Select Device for Target 1”对话框中选择合适的芯片。由于我采用的是STM32F103ZET6,所以选择ST – STM32F103ZE。

选择好芯片之后,会弹出一个消息框,“Copy STM32 Startup Code to Project Folder and Add File to Project?”问你是否需要加载启动代码。选择“是”后进入工程。

所谓启动代码,就是处理器在启动的时候执行的一段代码,主要任务是初始化处理器模式,设置堆栈,初始化变量等等。由于以上的操作均与处理器体系结构和系统配置密切相关,所以一般由汇编来编写。而对于初学者而言,自己设计启动代码有一定的难度,MDK开发平台内置了一些常用芯片的启动代码,因此在新建工程的时候,最好是采用默认的启动代码。当然,芯片制造厂商也会自己编写一些启动代码,放在官网上供开发者下载。

进入工程之后,我们就可以开始写代码了。首先得新建一个文件,然后将其保存成为*.c的格式,这样开发环境就可以识别出编写的代码里面一些常用的关键字和其他信息了。我就直接保存成为main.c。然后在屏幕左边的Project Workspace中的Source Group 1单击右键,选择Add Files to Group “ Source Group 1”,将我们刚刚保存起来的main.c添加到Source Group 1中,或者直接双击Source Group 1,也可以添加文件。

接下来就可以开始写代码了,对于初学者而言,最基础的操作应该是对芯片IO口的操作了。因此我在学习ARM的时候,第一个工程就选择了让开发板上的3个LED灯顺序点亮。STM32F103VET6中一共有A-G共7组通用输入输出接口(General-Purpose Inputs/Outputs),每个GPIO引脚都可以由软件配置成输出(推挽或开漏)、输入(带或不带上拉或下拉)或复用的外设功能端口。多数GPIO引脚都与数字或模拟的复用外设共用。具体的细节请参考Datasheet。

回到MDK开发平台,现在要在main.c中加入相关代码了。代码清单如下:

#include "stm32f10x_lib.h"

 

int main()

{

       int i;

       RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD|RCC_APB2Periph_GPIOB, ENABLE);                                                         //开启外设时钟

       GPIOD->CRL = 0x33333333;                           //设置端口配置寄存器

       GPIOB->CRL = 0x33333333;

       while(1)

       {             

              GPIOD->ODR = 0xffffffbf;                       //设置端口输出寄存器

              for(i=0;i<1000000;i++);                                   //延时

              GPIOD->ODR = 0xffffffff7;

              for(i=0;i<1000000;i++);

              GPIOD->ODR = 0x00000000;

              GPIOB->ODR = 0xffffffff;

              for(i=0;i<1000000;i++);

              GPIOB->ODR = 0x00000000;

       }

}

上述代码中,#include "stm32f10x_lib.h"包含了开发stm32f10x系列芯片所需的基本头文件,在进行程序编写的时候,务必要包含此头文件。

RCC_APB2PeriphClockCmd()函数是设置外设时钟。ARM与C51单片机不同的是,不用外设的时候,如IO口、ADC、定时器等等,都是禁止时钟的,以达到节能的目的,只有要用到的外设,才开启它的时钟。因此在需要用到GPIOB和GPIOD的时候,我们需要先开启它的时钟,具体用到的是函数库里面的函数:

void RCC_APB2PeriphClockCmd(uint32_t RCC_APB2Periph, FunctionalState NewState)

其中,第一个参数需要指示要开启什么端口的时钟,RCC_APB2Periph_GPIOx就是开启GPIOx的时钟,第二个参数需要指示是开启还是关闭,ENABLE/DISABLE。

开启外设时钟之后,然后就开始对GPIO的配置寄存器进行设置了,具体设置方式参考《基于MDK的STM32处理器开发应用》一书中,“7.1 通用IO端口”。While循环里面就是给GPIO的端口输出寄存器赋值,由于我手上这款奋斗开发板的三个LED灯分别接的是D3、D6和B5,所以只要将D端口和B端口相应的位上置1就可以了。

编译之后我们发现编译器报错,Undefined symbol RCC_APB2PeriphClockCmd,是因为我们使用了的RCC_APB2PeriphClockCmd()函数在头文件中声明了,却没有在C文件中定义,这个函数在.. KeilARMRV31LIBSTSTM32F10xstm32f10x_rcc.c中,将这个文件复制到工程的根目录下,然后在屏幕左边的Workspace中添加进来,就可以了。

其实,在MDK的库中,还定义了很多宏,可以避免让我们自己去查找相关资料来设置寄存器的各个位。比如,在本次实验中,对于LED等的亮灭也可以通过以下代码来实现。

 

#include "stm32f10x_lib.h"

 

int main()

{

        

       int i;

       GPIO_InitTypeDef GPIO_InitStructure;             //定义GPIO宏操作结构体

 

       RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD | RCC_APB2Periph_GPIOB,ENABLE);              //外设时钟配置,开启GPIOB和GPIOD的时钟   

       GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5;                               

       GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;               //将B5口配置为通用推挽输出

       GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;           //口线翻转速度为50MHz

       GPIO_Init(GPIOB, &GPIO_InitStructure);                                  //配置GPIOB口

      

       GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6|GPIO_Pin_3;            //将D3和D6口配置为推挽输出

       GPIO_Init(GPIOD, &GPIO_InitStructure);                                    //配置GPIOD口

 

       while(1)

       {

              GPIO_SetBits(GPIOB, GPIO_Pin_5);                             //B5口输出高电平

              GPIO_ResetBits(GPIOD, GPIO_Pin_6);                          //D6口输出低电平

              GPIO_ResetBits(GPIOD, GPIO_Pin_3);                           //D3口输出低电平

 

              for(i=0;i<1000000;i++);

 

              GPIO_ResetBits(GPIOB, GPIO_Pin_5);

              GPIO_ResetBits(GPIOD, GPIO_Pin_6);

              GPIO_SetBits(GPIOD, GPIO_Pin_3);

 

              for(i=0;i<1000000;i++);

 

              GPIO_ResetBits(GPIOB, GPIO_Pin_5);

              GPIO_ResetBits(GPIOD, GPIO_Pin_3);

              GPIO_SetBits(GPIOD, GPIO_Pin_6);

 

              for(i=0;i<1000000;i++);

       }

}

 

由于我们使用了GPIO_InitTypeDef类型,所以我们需要找到它的定义,这个定义包含在“…KeilARMRV31LIBSTSTM32F10xstm32f10x_gpio.c”中,将文件复制到工程根目录下,然后再添加进入工程中,编译才不会报错。

在绝大多数C编译器中,要求所有的变量声明都在执行语句块之前,也就是说如果需要定义的变量需要先在进入main函数一开始就全部定义好,如果执行了某一条语句之后再定义变量的话,就会报错。


关键字:STM32  GPIO口 引用地址:STM32 GPIO口的使用

上一篇:STM32-中断应用
下一篇:STM32定时器初步

推荐阅读最新更新时间:2024-03-16 15:41

STM32 FSMC驱动TFTLCD 难点解析
本篇文章三个主题:FSMC有关配置、一串字符显示原理、汉字显示原理。。下面进入正题 一、FSMC的有关配置(博主用的是FSMC_A10): 来自别人家的博客http://blog.csdn.net/jxnu_xiaobing/article/details/8718566 FSMC的介绍就不介绍了,网上一大片。我们就讨论讨论为什么用FSMC的地址线与TFTLCD的RS引脚相连?以及我们如何往LCD写数据/命令? FSMC称为可变静态存储控制器。可变:之所以称为“可变”,是由于通过对特殊功能寄存器的设置,FSMC 能够根据不同的外部存储器类型,发出相应的数据/地址/控制信号类型以匹配信号的速度。(这点很重要,后文会
[单片机]
<font color='red'>STM32</font> FSMC驱动TFTLCD 难点解析
STM32学习笔记(六)---EXTI
EXTI: 外部中断/事件控制器 一、EXTI简介 外部中断/事件控制器包含多大23个用于产生事件/中断请求的边沿检测器。 每根输入线都可单独进行配置:选择类型(中断/事件)和相应的触发事件(上升沿、下降沿或边沿触发) 每根输入线可单独屏蔽。 注意:检测脉冲宽度低于APB2时钟宽度的外部信号 二、EXTI框图 EXITI可分为两大功能:产生中断和产生事件 1. 产生中断 红色虚线指示的流程 编号1:输入线可以通过寄存器设置为任意一个GPIO,也可以是一些外设的事件。 编号2:边沿检测电路检测到EXTI_RTSR(上边沿寄存器)或EXTI_FTSR(下边沿寄存器)有效信号就输出1无效信号输出0 编号3:或门电
[单片机]
<font color='red'>STM32</font>学习笔记(六)---EXTI
SWD调试在STM32中REMAP调试的深入探究
首先说一下问题的现象,如果有这种现象的同学可以看看博主的这篇博文程序download一次后,第二次download就提示no target connect,除非长按reset键才能继续下载程序 首先上一组stm32的TIM2的端口使用组合有下面四种: 1.当不重映射时,默认TIM2四个的IO口是PA0、PA1、PA2、PA3 开启重映射__HAL_AFIO_REMAP_TIM2_ENABLE() 2.要使用PA15、PB3、PA2、PA3的端口组合,要调用下面的语句进行部分重映射: __HAL_AFIO_REMAP_TIM2_PARTIAL_1() 3.要使用PA0、PA1、PB10、PB11的端口组合,要调用下面的
[单片机]
STM32单片机GPIO概述及相关寄存器
5.1 STM32单片机GPIO概述 STM32中每个IO口都有很多个作用,比如这次我们使用的STM32F103ZET6的PA0口,既可以作为IO口使用,还可以作为待机唤醒(WAKEUP),模拟输入(ADC功能)等。根据数据手册中列出的每个I/O端口的特定硬件特征,GPIO端口的每个位可以由软件分别配置成多种模式。 (1)输入浮空 (2)输入上拉 (3)输入下拉 (4)模拟输入 (5)开漏输出 (6)推挽式输出 (7)推挽式复用功能 (8)开漏复用功能 每个I/O端口位可以自由编程,然而I/O端口寄存器必须按32位字被访问(不允许半字或字节访问)。GPIOx_BSRR和GPIOx_BRR寄存器允许对任何GPIO寄存器的读/
[单片机]
<font color='red'>STM32</font>单片机<font color='red'>GPIO</font>概述及相关寄存器
STM32 F103USB官方例程枚举知识
下面是USB枚举方面用到的一些函数以及他们之间的调用关系,由于本人刚刚接触STM32,可能会有一些错误,还望指正
[单片机]
<font color='red'>STM32</font> F103USB官方例程枚举知识
基于stm32的usb iap程序升级步骤
usb自动更新程序IAP(in application programming)DFU(develepment firemeware upgrate).整个芯片有512k的片内flash,用户程序下载在里面运行,flash的地址是0x8000000,大小为0x80000,usb自动更新程序首先下载0x8000000——0x80002FFF,总大小为12K,用户程序下载到0x80003000,大小为0x7D000(500K),usb自动更新代码为如下,如果按键按下,就进入DFU模式,否则就启动用户代码。 用户程序除了在void NVIC_Configuration(void) { /* Set the Vector Table
[单片机]
STM32单片机半主机模式的应用
在keil中编程时常会遇到__use_no_semihosting_swi的警告,这时你就是进入了半主机模式。 在嵌入式的编程中你是避免不了使用printf、fopen、fclose等函数的但是因为嵌入式的程序中并没有对这些函数的底层实现,使得设备运行时会进入软件中断BAEB处,这时就需要__use_no_semihosting_swi这 个声明,使程序遇到这些文件操作函数时不停在此中断处,具体操作如下,将下列程序加入你的工程中: #pragmaimport(__use_no_semihosting_swi)#pragmaimport(_main_redirection)constchar__stdin_name[150]
[单片机]
STM32调试SP3485技术总结
1、本文使用的STM32芯片是STM32F103RB,使用的资源是片内的USART1。 2、下面是我的电路连接图: 注:电路可以稍做修改更好,在B和A分别接下拉电阻到地和上拉电阻到5v,阻值选择为10K即可,这是为了在没有进行数据传输时保证两条数据线的状态为确定值。 做一下简单的说明: (1)PA8是sp3485的发送/接收使能端,sp3485只能支持半双工的通信,所以这个引脚就是来控制这个芯片到底是收数据还是发数据的。 (2)在有些电路连接中,sp3485的A和B端会一个被连接一个上拉电阻到3.3V,另一个会连接一个下拉电阻到GND,这样做的目的是当本sp3485不参与通信时不会影响网络的稳定性。 3、本次调试方式 PC
[单片机]
<font color='red'>STM32</font>调试SP3485技术总结
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
热门活动
换一批
更多
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
更多每日新闻
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved