ARM:作业2

1.复习串口实验的流程,熟练编写代码

2.串口发送指令控制硬件工作

a b c d

led1_on led1_off

代码:

main.c

cs 复制代码
#include "uartt.h"

//封装延时函数

void delay(int ms)

{

	int i,j;

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

	{

		for(j=0;j<2000;j++);

	}

}

int main()

{

	all_led_init1();

	//1.串口初始化

	uart4_init();

	char a;

	//现象是发送一个a串口工具打印一个b

    while(1)

    {

        //2.从串口读取一个字符

        a=mygetchar();

        //3.将读取到的字符+1发送回去

        myputchar(a);

		if(a == 'a')

		{

			led1_on1();

			led2_off1();

			led3_off1();

		}

		else if(a == 'b')

		{

			led1_off1();

			led2_on1();

			led3_off1();

		}

		else if(a == 'c')

		{

			led1_off1();

			led2_off1();

			led3_on1();

		}

    }



	return 0;

}

uartt.c

cs 复制代码
#include "uartt.h"

//串口初始化
void uart4_init()
{
    //1.UART4和GPIOB\GPIOG的时钟使能
    RCC->MP_AHB4ENSETR |= (0x1<<2);//使能GPIOB时钟
    RCC->MP_AHB4ENSETR |= (0x1<<6);//使能GPIOG时钟
    RCC->MP_APB1ENSETR |= (0X1<<16);//使能UART4时钟

    //2.设置PB2和PG11的管脚复用
    GPIOB->MODER &= (~(0x3<<4));
    GPIOB->MODER |= (0x2<<4); //设置复用
    GPIOB->AFRL &= (~(0XF<<8));
    GPIOB->AFRL |= (0X8<<8);//设置uart4功能复用
    GPIOG->MODER &= (~(0x3<<22));
    GPIOG->MODER |= (0x2<<22); //设置复用
    GPIOG->AFRH &= (~(0XF<<12));
    GPIOG->AFRH |= (0X6<<12);//设置uart4功能复用

    //3.先去设置串口禁用,方便设置数据格式
    USART4->CR1 &= (~0X1);
    
    //4.设置8位数据位
    USART4->CR1 &=(~(0x1<<28));
    USART4->CR1 &=(~(0x1<<12));

    //5.设置没有奇偶校验
    USART4->CR1 &=(~(0x1<<10));

    //6.设置16倍采样
    USART4->CR1 &=(~(0x1<<15));

    //7.设置1位停止位
    USART4->CR2 &=(~(0x3 <<12));

    //8.设置1分频
    USART4->PRESC &=(~(0xf << 0));

    //9.设置波特率为115200bps
    USART4->BRR = 0x22b;

    //10.发送器、接收器使能
    USART4->CR1 |=(0x1<<3);
    USART4->CR1 |=(0x1<<2);
    
    //11.串口使能
	USART4->CR1 |= (0x1 << 0);

}

//封装函数发送一个字符数据
void myputchar(char i)
{
    //1.判断TDR寄存器是否为空,如果为空,向TDR寄存器中写入数据
    while(!(USART4->ISR & (0x1 << 7)));
    USART4->TDR = i;
    //2.阻塞等待数据传输完成,函数返回
    while(!(USART4->ISR & (0x1 << 6)));
}

char mygetchar()
{
    char c;
    //判断RDR寄存器是否有就绪数据,如果有就读取,否则等待
    while(!(USART4->ISR&(0X1<<5)));//数据传输完成,函数结束
    c=USART4->RDR;
    return c;
}


void all_led_init1()
{
  // 1.使能外设时钟
  RCC_MP_AHB4ENSETR |= (0x3 << 4);
  // 2.设置PF10 PE10 PE8为输出输出
  GPIOE->MODER &= (~(0x3 << 20));
  GPIOE->MODER |= (0x1 << 20);
  GPIOF->MODER &= (~(0x3 << 20));
  GPIOF->MODER |= (0x1 << 20);
  GPIOE->MODER &= (~(0x3 << 16));
  GPIOE->MODER |= (0x1 << 16);
  // 3.设置推挽输出
  GPIOE->OTYPER &= (~(0x1 << 10));
  GPIOF->OTYPER &= (~(0x1 << 10));
  GPIOE->OTYPER &= (~(0x1 << 8));
  // 4.设置输出速度为低速
  GPIOE->OSPEEDR &= (~(0x3 << 20));
  GPIOF->OSPEEDR &= (~(0x3 << 20));
  GPIOE->OSPEEDR&= (~(0x3 << 16));
  // 5.设置无上拉下拉
  GPIOE->PUPDR&= (~(0x3 << 20));
  GPIOF->PUPDR &= (~(0x3 << 20));
  GPIOE->PUPDR &= (~(0x3 << 16));
}

void led1_on1()
{

  GPIOE->ODR |= (0x1 << 10);
}
void led2_on1()
{

  GPIOF->ODR|= (0x1 << 10);
}
void led3_on1()
{

  GPIOE->ODR |= (0x1 << 8);
}

void led1_off1()
{
  GPIOE->ODR &= (~(0x1 << 10));
}
void led2_off1()
{
  GPIOF->ODR &= (~(0x1 << 10));
}
void led3_off1()
{
  GPIOE->ODR &= (~(0x1 << 8));
}

uartt.h

cs 复制代码
#ifndef __UARTT_H__
#define __UARTT_H__
#include"stm32mp1xx_gpio.h"
#include"stm32mp1xx_rcc.h"
#include"stm32mp1xx_uart.h"

#define RCC_MP_AHB4ENSETR (*(unsigned int *)0X50000a28)

void uart4_init();
void myputchar(char i);
char mygetchar();

void all_led_init1();
void led1_on1();
void led2_on1();
void led3_on1();
void led1_off1();
void led2_off1();
void led3_off1();
#endif

运行结果:

相关推荐
VekiSon2 小时前
Linux内核驱动——设备树原理与应用
linux·c语言·arm开发·嵌入式硬件
代码游侠4 小时前
复习——Linux设备驱动开发笔记
linux·arm开发·驱动开发·笔记·嵌入式硬件·架构
陌上花开缓缓归以1 天前
LiteOS和RTOS 系统选型分析
arm开发
深圳市九鼎创展科技1 天前
瑞芯微 RK3399 开发板 X3399 评测:高性能 ARM 平台的多面手
linux·arm开发·人工智能·单片机·嵌入式硬件·边缘计算
森焱森1 天前
嵌入式硬件工程师应知 白银快速分析报告
linux·c语言·arm开发·嵌入式硬件·去中心化
森G2 天前
七、04ledc-sdk--------makefile有变化
linux·c语言·arm开发·c++·ubuntu
VekiSon2 天前
Linux内核驱动——杂项设备驱动与内核模块编译
linux·c语言·arm开发·嵌入式硬件
AI+程序员在路上2 天前
Nand Flash与EMMC区别及ARM开发板中的应用对比
arm开发
17(无规则自律)2 天前
深入浅出 Linux 内核模块,写一个内核版的 Hello World
linux·arm开发·嵌入式硬件
梁洪飞3 天前
内核的schedule和SMP多核处理器启动协议
linux·arm开发·嵌入式硬件·arm