12.25

led.c

#include "led.h"
void all_led_init()
{RCC_GPIO |= (0X3<<4);//时钟使能GPIOE_MODER &=(~(0X3<<20));//设置PE10输出GPIOE_MODER |= (0X1<<20);//设置PE10为推挽输出GPIOE_OTYPER &=(~(0x1<<10));//PE10为低速输出GPIOE_OSPEEDR &= (~(0x3<<20));//设置无上拉下拉GPIOE_PUPDR &= (~(0x3<<20));//LED2GPIOF_MODER &=(~(0X3<<20));//设置Pf10输出GPIOF_MODER |= (0X1<<20);//设置Pf10为推挽输出GPIOF_OTYPER &=(~(0x1<<10));//Pf10为低速输出GPIOF_OSPEEDR &= (~(0x3<<20));//设置无上拉下拉GPIOF_PUPDR &= (~(0x3<<20));//LED3GPIOE_MODER &=(~(0X3<<16));//设置PE8输出GPIOE_MODER |= (0X1<<16);//设置PE8为推挽输出GPIOE_OTYPER &=(~(0x1<<8));//PE8为低速输出GPIOE_OSPEEDR &= (~(0x3<16));//设置无上拉下拉GPIOE_PUPDR &= (~(0x3<<16));
}
void led1_on()
{GPIOE_ODR |= (0x1<<10);
}void led1_off()
{GPIOE_ODR &= (~(0x1<<10));
}
void led2_on()
{GPIOF_ODR |= (0x1<<10);
}void led2_off()
{GPIOF_ODR &= (~(0x1<<10));
}
void led3_on()
{GPIOE_ODR |= (0x1<<8);
}void led3_off()
{GPIOE_ODR &= (~(0x1<<8));
}

led.h

#ifndef __LED_H_
#define __LED_H_#define RCC_GPIO     (*(unsigned int *)0x50000a28)
#define GPIOE_MODER     (*(unsigned int *)0x50006000)
#define GPIOF_MODER     (*(unsigned int *)0x50007000)
#define GPIOE_OTYPER     (*(unsigned int *)0x50006004)
#define GPIOF_OTYPER     (*(unsigned int *)0x50007004)
#define GPIOF_OSPEEDR     (*(unsigned int *)0x50007008)
#define GPIOE_OSPEEDR     (*(unsigned int *)0x50006008)
#define GPIOF_PUPDR      (*(unsigned int *)0x5000700C)
#define GPIOE_PUPDR     (*(unsigned int *)0x5000600C)
#define GPIOE_ODR     (*(unsigned int *)0x50007014)
#define GPIOF_ODR     (*(unsigned int *)0x50006014)void led1_on();
void led2_on();
void led3_on();
void led1_off();
void led2_off();
void led3_off();void delay(int ms);void all_led_init();
#endif

uart4.h

#ifndef __UART4_H_
#define __UART4_H_
#include "stm32mp1xx_rcc.h"
#include "stm32mp1xx_gpio.h"
#include"stm32mp1xx_uart.h"
void uart4_config();
void putchar(char a);
char getchar();
int cmp(char  *s1,char *s2);
void puts(char *s);
void gets(char *s);
#endif
#include"uart4.h"#include "led.h"int main(){char st[100];all_led_init();uart4_config();while(1){gets(st);puts(st);if(cmp(st,"open")==0){led1_on();led2_on();led3_on();}if(cmp(st,"close")==0){led1_off();led2_off();led3_off();}}return 0;}

main.c

uart4.c

#include "uart4.h"
void uart4_config()
{//使能GPIOB/GPIOG/UART4外设时钟RCC->MP_AHB4ENSETR |=(0x1<<1);RCC->MP_AHB4ENSETR |=(0x1<<6);RCC->MP_APB1ENSETR |=(0x1<<16);//设置PB2/PG11用于UART4为复用功能
GPIOB->MODER &=(~(0X3<<4));
GPIOB->MODER |=(0X2<<4);
GPIOB->AFRL &=(~(0Xf<<8));
//原来没有移动,下面也是
GPIOB->AFRL |=(0x8<<8);//pg11
GPIOG->MODER  &=(~(0X3<<22));
//这一整块都移动错误
GPIOG->MODER |=(0X2<<22); 
GPIOG->AFRH &=(~(0Xf<<12));
//最后一个写成L
GPIOG->AFRH |=(0x6<<12);//串口禁用
USART4->CR1 &=(~0x1);
// UART4->CR1 |=(0x1)
//设置数据位宽为8位
USART4->CR1 &=(~(0x1<<12));
USART4->CR1 &=(~(0x1<<28));
//?//设置无奇偶校验位
USART4->CR1 &=(~(0x1<<10));
//设置16倍过采样
USART4->CR1 &=(~(0x1<<15));
//设置1位停止位
USART4->CR2 &=(~(0x3<<12));
//设置不分频
USART4->PRESC &=(~(0xf));
//设置波特率为115200USART4->BRR =0X22B;
//使能发送器
USART4->CR1 |=(0X1<<3);
//使能接收器
USART4->CR1 |=(0X1<<2); 
//使能串口
USART4->CR1 |=(0X1);}
void putchar(char a )
{//判断是发送器否为空,不为空等待
while(!(USART4->ISR &(0X1<<7))); //向发送寄存器写入数据USART4->TDR=a ;
//等待发送完成while(!(USART4->ISR &(0x1<<6)));
}
char getchar()
{
//判断接收器是否有准好的数据,没有就等待
char a;while(!(USART4->ISR &(0X1<<5)));
//读取数据a=USART4->RDR;//返回return a;
}void gets(char *s)
{while(1){*s=getchar();if(*s=='\r'){break;}s++;}*s='0';}
void puts(char *s)
{while(1){putchar(*s);s++;}putchar('\r');putchar('\n');}
int cmp(char  *s1,char *s2)
{int i = 0;while(((*(s1+i))==(*(s2+i)))){i++;if( (*(s1+i)=='\0')){break;}}int sub = ((*(s1+i))-(*(s2+i)));if(sub>0){return sub;}else if(sub<0){return sub;}else{return 0;			}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/300632.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【深度学习目标检测】十一、基于深度学习的电网绝缘子缺陷识别(python,目标检测,yolov8)

YOLOv8是一种物体检测算法&#xff0c;是YOLO系列算法的最新版本。 YOLO&#xff08;You Only Look Once&#xff09;是一种实时物体检测算法&#xff0c;其优势在于快速且准确的检测结果。YOLOv8在之前的版本基础上进行了一系列改进和优化&#xff0c;提高了检测速度和准确性。…

C# 读取Word表格到DataSet

目录 功能需求 Office 数据源的一些映射关系 范例运行环境 配置Office DCOM 关键代码 组件库引入 ​核心代码 杀掉进程 总结 功能需求 在应用项目里&#xff0c;多数情况下我们会遇到导入 Excel 文件数据到数据库的功能需求&#xff0c;但某些情况下&#xff0c;也存…

深圳锐科达SIP矿用电话模块SV-2801VP

深圳锐科达SIP矿用电话模块SV-2801VP 一、简介 SV-2800VP系列模块是我司设计研发的一款用于井下的矿用IP音频传输模块&#xff0c;可用此模块打造一套低延迟、高效率、高灵活和多扩展的IP矿用广播对讲系统&#xff0c;亦可对传统煤矿电话系统加装此模块&#xff0c;进行智能化…

OpenCV之图像匹配与定位

利用图像特征的keypoints和descriptor来实现图像的匹配与定位。图像匹配算法主要有暴力匹配和FLANN匹配&#xff0c;而图像定位是通过图像匹配结果来反向查询它们在目标图片中的具体坐标位置。 以QQ登录界面为例&#xff0c;将整个QQ登录界面保存为QQ.png文件&#xff0c;QQ登…

B/S和C/S的区别和联系

B/S和C/S的区别和联系 1 B/S2 C/S3 B/S和C/S区别4 B/S和C/S联系 1 B/S B/S&#xff08;Brower/Server&#xff09;架构&#xff0c;也称为B/S结构或B/S模式&#xff0c;是Web兴起后的一种网络结构模式。在这种模式下&#xff0c;Web浏览器成为客户端最主要的软件。系统功能实现…

odoo17核心概念view5——ir_ui_view.py

这是view系列的第5篇文章&#xff0c;介绍一下view对应的后端文件ir_ui_view.py&#xff0c;它是base模块下的一个文件 位置&#xff1a;odoo\addons\base\models\ir_ui_view.py 该文件一共定义了三个模型 1.1 ir.ui.view.custom 查询数据库这个表是空的&#xff0c;从名字看…

STM32独立看门狗

时钟频率 40KHZ 看门狗简介 STM32F10xxx 内置两个看门狗&#xff0c;提供了更高的安全性、时间的精确性和使用的灵活性。两个看 门狗设备 ( 独立看门狗和窗口看门狗 ) 可用来检测和解决由软件错误引起的故障&#xff1b;当计数器达到给 定的超时值时&#xff0c;触发一个中…

HarmonyOS共享包HAR

共享包概述 OpenHarmony提供了两种共享包&#xff0c;HAR&#xff08;Harmony Archive&#xff09;静态共享包&#xff0c;和HSP&#xff08;Harmony Shared Package&#xff09;动态共享包。 HAR与HSP都是为了实现代码和资源的共享&#xff0c;都可以包含代码、C库、资源和配…

基于java+控件台+mysql的学生信息管理系统(含演示视频)

基于java控件台mysql的学生信息管理系统_含演示视频 一、系统介绍二、功能展示1.项目内容2.项目骨架3.数据库4.登录系统5.新增学生6.查询学生7.修改学生8.删除学生9.退出系统 四、其它1.其他系统实现五.获取源码 一、系统介绍 项目类型&#xff1a;Java SE项目&#xff08;控制…

云计算、大数据、人工智能、物联网、虚拟现实技术、区块链技术(新一代信息技术)学习这一篇够了!

目录 云计算 一、云计算的基本概念 二、云计算的分类 (一) IaaS (二) SaaS (三) PaaS 三、云环境的分类、云计算的四种部署模式 (一)公有云 (二)私有云 (三)社区云 (四)混合云 四、云计算的特点 (一)虚拟化技术 (二)动态可扩展 (三)按需部署 (四)灵活性高 (五…

算法leetcode|94. 二叉树的中序遍历(多语言实现)

文章目录 94. 二叉树的中序遍历&#xff1a;样例 1&#xff1a;样例 2&#xff1a;样例 3&#xff1a;提示&#xff1a; 分析&#xff1a;题解&#xff1a;rust&#xff1a;go&#xff1a;c&#xff1a;python&#xff1a;java&#xff1a; 94. 二叉树的中序遍历&#xff1a; …

OpenCV-Python(14):图像几何变换

背景说明 图像几何变换是计算机视觉和图像处理领域中的重要技术。它通过对图像进行平移、旋转、缩放、翻转等操作&#xff0c;改变图像的大小、位置或方向&#xff0c;以实现对图像的变换和处理。 图像几何变换在很多应用中都有广泛的应用&#xff0c;例如&#xff1a; 视觉定…