当前位置: 首页 > news >正文

通过操作Cortex-A7核,串口输入相应的命令,控制LED灯进行工作增加编程要求

2.编程要求:

1)结构体封装

typedef struct{

char* cmd_arr; //命令行字符串

gpio_t* gpiox;//GPIO组号

unsigned int pin; //引脚编号

status_t status; //LED灯状态

void(*gpio_write_pin)(gpio_t* gpiox,unsigned int pin,status_t status);

}cmd_t;

2)结构体数组

方式1:cmd_t cmd_arr[6] = {{"led1off",GPIOE,GPIO_PIN_10,GPIO_RESET_T},{},};

cmd_t cmd_arr[6] = {

[0] ={

.cmd_arr = "led1off",

.gpiox = GPIOE,

.pin = GPIO_PIN_10,

.status = GPIO_RESET_T,

.gpio_write_pin = hal_gpio_write, },

[1] = {},

[2] = {}, };

3)在串口输入一个字符串

1>在串口输入一个字符串,需要定义一个变量接收,串口接收到的字符串 char* string = uart_get_string();

2>串口中输入的字符串,与结构体中每个元素中的cmd_arr变量进行比较

3>如果比较成功,代表查到输入的字符串

思考:函数实现如何编写?

cmd_t* find_command(const char* str)

{

//串口中输入的字符串,与结构体中每个元素中的cmd_arr变量进行比较

//遍历比较,自己编写strcmp比较的函数

return 0;//失败返回0 }

4)思考main.c函数编写

cmd_t* cmd_arr;

char* string = uart_get_string();

cmd_arr = find_command(string);

if(cmd_arr == 0){

查找失败

}else

{

cmd_arr->gpio_write_pin(cmd_arr->gpiox,...........) }

实现结果:

头文件:

#ifndef __UART_LED_H__
#define __UART_LED_H__#include "stm32mp1xx_gpio.h"
#include "stm32mp1xx_rcc.h"
#include "stm32mp1xx_uart.h"
#include "gpio.h"
typedef struct{char * cmd_str;gpio_t* gpiox;unsigned int pin;status_t status;void (*gpio_write_pin)(gpio_t* gpiox,unsigned int pin,status_t status);
}cmd_t;//串口初始化
void uart_init();//发送一个字符
void uart_put_char(const char str);//发送一个字符串
void uart_put_string(const char *str);//接收一个字符
char uart_get_char();//接收一个字符串
char* uart_get_string();void led1_init();void led2_init();void led3_init();//控制LED灯亮灭#endif

源文件:

#include"uart_led.h"
extern void delay_ms(int ms);void uart_init()
{RCC->MP_AHB4ENSETR |= (0x1<<1);RCC->MP_AHB4ENSETR |=(0x1<<6);RCC->MP_AHB4ENSETR |=(0x1<<16);GPIOB->MODER &= (~(0x3<<4));GPIOB->MODER |=(0x1<<5);GPIOG->MODER &=(~(0x3<<22));GPIOG->MODER |=(0x1<<23);GPIOB->AFRL &=(~(0xf<<8));GPIOB->AFRL |=(0x1<<11);GPIOG->AFRH &=(~(0xf<<12));GPIOG->AFRH |=(0x6<<12);if(USART4->CR1 &=(0x1)){delay_ms(500);USART4->CR1 &= (~(0x1));}USART4->CR1 &=(~(0x1<<28));USART4->CR1 &=(~(0x1<<12));USART4->CR1 &=(~(0x1<<15));USART4->CR1 &=(~(0x1<<10));USART4->CR1 |=(0x1<<3);USART4->CR1 |=(0x1<<2);USART4->CR2 &=(~(0x3<<12));USART4->BRR |=0x22b;USART4->PRESC &= (~(0xf));USART4->CR1 |=(0x1);}//发送一个字符
void uart_put_char(const char str)
{while(!(USART4->ISR &(0x1<<7)));USART4->TDR =str;while(!(USART4->ISR &(0x1<<6)));
}//发送一个字符串
void uart_put_string(const char *str)
{while(!(USART4->ISR &(0x1<<7)));int i=0;while(str[i]!='\0'){USART4->TDR = str[i];i++;}}//接收一个字符
char uart_get_char()
{char ch;while(!(USART4->ISR &(0x1<<5)));ch=USART4->RDR;return ch;
}//接收一个字符串
char  buffer[50]={0};
char* uart_get_string()
{int i=0;for(i=0;i<47;i++){buffer[i]=uart_get_char();uart_put_char(buffer[i]);if(buffer[i]=='\r')break;}buffer[i]='\0';uart_put_char('\n');return buffer;
}void led1_init()
{RCC->MP_AHB4ENSETR |=(0x1<<4);GPIOE->MODER &=  (~(0x3<<20));GPIOE->MODER|= (0x1<<20);GPIOE->OTYPER &= (~(0x1<<10));GPIOE->OSPEEDR &= (~(0x3<<20));GPIOE->PUPDR &= (~(0x3<<20));}void led2_init()
{RCC->MP_AHB4ENSETR |=(0x1<<5);GPIOF->MODER &=  (~(0x3<<20));GPIOF->MODER|= (0x1<<20);GPIOF->OTYPER &= (~(0x1<<10));GPIOF->OSPEEDR &= (~(0x3<<20));GPIOF->PUPDR &= (~(0x3<<20));}void led3_init()
{RCC->MP_AHB4ENSETR |=(0x1<<4);GPIOE->MODER &=  (~(0x3<<16));GPIOE->MODER|= (0x1<<16);GPIOE->OTYPER &= (~(0x1<<8));GPIOE->OSPEEDR &= (~(0x3<<16));GPIOE->PUPDR &= (~(0x3<<16));}void hal_gpio_write(gpio_t * gpiox,unsigned int pin,status_t status)
{if(status==gpio_reset_t){gpiox->ODR &= (~(0x1<<pin));}else{gpiox->ODR |= (0x1<<pin);}
}

测文件:

#include "uart_led.h"extern void printf(const char *fmt, ...);void delay_ms(int ms){int i,j;for(i = 0; i < ms;i++)for (j = 0; j < 1800; j++);}cmd_t cmd_arr[6]={[0] ={.cmd_str ="led1_up",.gpiox=GPIOE,.pin=GPIO_PIN_10,.status=gpio_set_t,.gpio_write_pin=hal_gpio_write,},[1] ={.cmd_str ="led1_off",.gpiox=GPIOE,.pin=GPIO_PIN_10,.status=gpio_reset_t,.gpio_write_pin=hal_gpio_write,},[2] ={.cmd_str ="led2_up",.gpiox=GPIOF,.pin=GPIO_PIN_10,.status=gpio_set_t,.gpio_write_pin=hal_gpio_write,},[3] ={.cmd_str ="led2_off",.gpiox=GPIOF,.pin=GPIO_PIN_10,.status=gpio_reset_t,.gpio_write_pin=hal_gpio_write,},[4] ={.cmd_str ="led3_up",.gpiox=GPIOE,.pin=GPIO_PIN_8,.status=gpio_set_t,.gpio_write_pin=hal_gpio_write,},[5] ={.cmd_str ="led3_off",.gpiox=GPIOE,.pin=GPIO_PIN_8,.status=gpio_reset_t,.gpio_write_pin=hal_gpio_write,},};cmd_t* find_command(char *str1){int j,i;for( j=0;j<6;j++){for(i=0;str1[i]!='\0';i++){if(str1[i]!=cmd_arr[j].cmd_str[i]){break;}}if(str1[i]=='\0'){return cmd_arr+j;}}return 0;}int main(){//串口初始化//实现串口数据收发led1_init();led2_init();led3_init();uart_init();cmd_t* cmd_ack;while(1){char *str=uart_get_string();cmd_ack=find_command(str);if(cmd_ack==0){printf("查找失败\n");}else{cmd_ack->gpio_write_pin(cmd_ack->gpiox,cmd_ack->pin,cmd_ack->status);}}return 0;}

测试结果:

http://www.lryc.cn/news/18899.html

相关文章:

  • 银行家算法
  • 181、【动态规划】leetcode ——72. 编辑距离(C++版本)
  • mysql 中关于慢查询日志
  • 程序员必备的软技能-金字塔原理拆解(上)
  • 关于我利用python开发的PC端标注软件及目标检测软件
  • Git导出增量包的操作步骤
  • JavaWeb--JavaScript
  • mars3d加载建筑物白膜及简单建筑物样式
  • 数据结构之顺序表
  • 【数据挖掘实战】——家用电器用户行为分析及事件识别
  • 肠道核心菌属——双歧杆菌属,了解并拥有它
  • Python 之 Pandas 生成时间戳范围、Pandas 的时期函数 Period() 和时间序列 - 重采样 resample
  • 利用Python和Sprak求曲线与X轴上方的面积
  • 利用机器学习(mediapipe),进行人手的21个3D手关节坐标检测
  • 【添砖java】谁说编程第一步是hello world
  • el-table大数据量渲染卡顿问题
  • MyBatis-Plus 实现分页的几种写法
  • 记一次Binder内存不足导致的应用被杀
  • Zabbix4.0架构理解-zabbix的工作方式
  • MySQL中的一些非常实用的函数、语法
  • RT-Thread移植到STM32F407
  • VR全景到底有多全能?为何屡受关注?
  • 剑指 Offer 30. 包含min函数的栈
  • stm32f407探索者开发板(二十二)——通用定时器基本原理讲解
  • cmake 入门三 常用变量和指令
  • Linux基础命令-find搜索文件位置
  • 获取浏览器硬件资源的媒体数据(拍照、录音、录频、屏幕共享)
  • Java入门教程||Java 日期时间||Java 正则表达式
  • 详解八大排序算法
  • python库streamlit学习笔记