stm32f429discovery模板加入原子哥的延时串口和位带操作

本文主要是介绍stm32f429discovery模板加入原子哥的延时串口和位带操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

今天拿到了stm32f429 discovery的开发板,板子很强大但是还是从基础的程序来吧,写着帖子主要是为了参加eeworld的活动,但是吃水不忘挖井人,在原子哥的群里跟大家在分享一下。
在已经建立好工程模板的基础上,进一步加入简单的操作函数方便以后的编程,直接使用原子哥战舰开发板配套程序system文件夹里的函数,这跟文件夹里有延时函数,串口函数,位带操作函数,平常使用是非常方便,所以就把这个文件夹直接拷到stm32f429的工程模板中。

打开工程,在manage project items中新建sys文件夹,并将该文件夹下的.c文件添加进来,并且在options for target里c/c++选项卡中添加相应.h文件。类似于工程模板建立的过程。

延时函数和位带操作函数直接可以使用,串口初始化函数需要重新定义串口的引脚。具体程序:

void uart_init(u32 bound){

    //GPIO端口设置

    GPIO_InitTypeDef GPIO_InitStructure;

         USART_InitTypeDef USART_InitStructure;

         NVIC_InitTypeDef NVIC_InitStructure;

          

           /* Enable GPIOC and GPIOE clock */

  RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA , ENABLE);

        

           /* Enable USART1 APB clock */

  RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE);

           /* USART1 Pins configuration ************************************************/

  /* Connect pin to Periph */

  GPIO_PinAFConfig(GPIOA, GPIO_PinSource9, GPIO_AF_USART1);   

  GPIO_PinAFConfig(GPIOA, GPIO_PinSource10, GPIO_AF_USART1);

        

  /* Configure pins as AF pushpull */

  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;

  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;

  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;

  GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;

  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;

  GPIO_Init(GPIOA, &GPIO_InitStructure);             //TX

 

  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;

  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;

  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;

  GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;

  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;

  GPIO_Init(GPIOA, &GPIO_InitStructure);             //RX

 

   //Usart1 NVIC 配置

 

    NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;

         NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=3 ;//抢占优先级3

         NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;            //子优先级3

         NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;                    //IRQ通道使能

         NVIC_Init(&NVIC_InitStructure);    //根据指定的参数初始化VIC寄存器

 

   //USART 初始化设置

 

         USART_InitStructure.USART_BaudRate = bound;//一般设置为9600;

         USART_InitStructure.USART_WordLength = USART_WordLength_8b;//字长为8位数据格式

         USART_InitStructure.USART_StopBits = USART_StopBits_1;//一个停止位

         USART_InitStructure.USART_Parity = USART_Parity_No;//无奇偶校验位

         USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;//无硬件数据流控制

         USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;        //收发模式

 

    USART_Init(USART1, &USART_InitStructure); //初始化串口

    USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);//开启中断

    USART_Cmd(USART1, ENABLE);                    //使能串口

 

}

在真正使用的时候,因为原子哥对printf函数做了重定义,所以直接使用printf函数就可以了。

设置好后可以编写主函数了,就以一个闪烁灯+串口发送为例。程序如下:

#include "stm32f4xx.h"

#include <stdio.h>

#include "delay.h"

#include "sys.h"

#include "usart.h"

 

#define LED0 PGout(13)

#define LED1 PGout(14)

 

void LED_Init(void)

{

 

 GPIO_InitTypeDef  GPIO_InitStructure;

       

RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOG , ENABLE);         //??PE????

        

 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_13|GPIO_Pin_14;                                  

 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;                   //????

 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;             //IO????50MHz

 GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;

 GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;

 GPIO_Init(GPIOG, &GPIO_InitStructure);                                          //?????????GPIOB.5

        

 GPIO_ResetBits(GPIOG,GPIO_Pin_13);                                                       //PE ???

 GPIO_ResetBits(GPIOG,GPIO_Pin_14);        

}

 

 

int main(void)

{

         delay_init();

         LED_Init();

         uart_init(9600);

  while (1)

  {

                   LED0=1;                                                 

                   LED1=1;

                   delay_ms(500);

                   LED0=0;                                                 

                   LED1=0;

                   delay_ms(500);

                   printf("hello stm32f429\r\n");

  }

}

 

#define LED0 PGout(13),使用了位带操作,为了方便对引脚的操作,但是对引脚的初始化工作还是需要的。

 

在使用串口,延时函数前要先对其进行初始化,之后的程序就很简单了。编译下载到板子中测试一下。


 



附件1:  stm32f429 template.zip (文件大小: 572 KB 下载次数:2次) AttachmentIcon

这篇关于stm32f429discovery模板加入原子哥的延时串口和位带操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/680222

相关文章

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

Python使用DrissionPage中ChromiumPage进行自动化网页操作

《Python使用DrissionPage中ChromiumPage进行自动化网页操作》DrissionPage作为一款轻量级且功能强大的浏览器自动化库,为开发者提供了丰富的功能支持,本文将使用Dri... 目录前言一、ChromiumPage基础操作1.初始化Drission 和 ChromiumPage

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

Redis中管道操作pipeline的实现

《Redis中管道操作pipeline的实现》RedisPipeline是一种优化客户端与服务器通信的技术,通过批量发送和接收命令减少网络往返次数,提高命令执行效率,本文就来介绍一下Redis中管道操... 目录什么是pipeline场景一:我要向Redis新增大批量的数据分批处理事务( MULTI/EXE

使用Python高效获取网络数据的操作指南

《使用Python高效获取网络数据的操作指南》网络爬虫是一种自动化程序,用于访问和提取网站上的数据,Python是进行网络爬虫开发的理想语言,拥有丰富的库和工具,使得编写和维护爬虫变得简单高效,本文将... 目录网络爬虫的基本概念常用库介绍安装库Requests和BeautifulSoup爬虫开发发送请求解

C++中函数模板与类模板的简单使用及区别介绍

《C++中函数模板与类模板的简单使用及区别介绍》这篇文章介绍了C++中的模板机制,包括函数模板和类模板的概念、语法和实际应用,函数模板通过类型参数实现泛型操作,而类模板允许创建可处理多种数据类型的类,... 目录一、函数模板定义语法真实示例二、类模板三、关键区别四、注意事项 ‌在C++中,模板是实现泛型编程

Oracle存储过程里操作BLOB的字节数据的办法

《Oracle存储过程里操作BLOB的字节数据的办法》该篇文章介绍了如何在Oracle存储过程中操作BLOB的字节数据,作者研究了如何获取BLOB的字节长度、如何使用DBMS_LOB包进行BLOB操作... 目录一、缘由二、办法2.1 基本操作2.2 DBMS_LOB包2.3 字节级操作与RAW数据类型2.