ARM day5

作业:封装流水灯

led.h

cs 复制代码
#ifndef __LED_H__
#define __LED_H__

// 定义GPIO端口结构体,包含GPIO端口的各种寄存器
typedef struct
{
    unsigned int MODER;     // 端口模式寄存器
    unsigned int OTYPER;    // 端口输出类型寄存器
    unsigned int OSPEEDR;   // 端口速度寄存器
    unsigned int PUPDR;     // 端口上拉/下拉寄存器
    unsigned int IDR;       // 端口输入数据寄存器
    unsigned int ODR;       // 端口输出数据寄存器
    unsigned int BSRR;      // 端口位设置/重置寄存器
}gpio_t;

// 定义GPIOE和GPIOF的地址
#define GPIOE ((gpio_t *)0x50006000)
#define GPIOF ((gpio_t *)0x50007000)

void led1_init();


void led2_init();


void led3_init();

void led1_ctl(int flag);


void led2_ctl(int flag);


void led3_ctl(int flag);

#endif 

led.c

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

void led1_init()
{
    // 设置PE10为输出模式
    GPIOE->MODER &= (~(0x3 << 20));
    GPIOE->MODER |= (0x1 << 20);
    // 设置PE10为推挽输出
    GPIOE->OTYPER &= (~(0x1 << 10));
    // 设置PE10为低速输出
    GPIOE->OSPEEDR &= (~(0x3 << 20));
    // 设置PE10无上拉下拉
    GPIOE->PUPDR &= (~(0x3 << 20));
}
void led2_init()
{
    // 设置Pf10为输出模式
    GPIOF->MODER &= (~(0x3 << 20));
    GPIOF->MODER |= (0x1 << 20);
    // 设置PF10为推挽输出
    GPIOF->OTYPER &= (~(0x1 << 10));
    // 设置PF10为低速输出
    GPIOF->OSPEEDR &= (~(0x3 << 20));
    // 设置PF10无上拉下拉
    GPIOF->PUPDR &= (~(0x3 << 20));
}
void led3_init()
{
    // 设置PE8为输出模式
    GPIOE->MODER &= (~(0x3 << 16));
    GPIOE->MODER |= (0x1 << 16);

    // 设置PE8为推挽输出
    GPIOE->OTYPER &= (~(0x1 << 8));

    // 设置PE8为低速输出
    GPIOE->OSPEEDR &= (~(0x3 << 16));

    // 设置PE8无上拉下拉
    GPIOE->PUPDR &= (~(0x3 << 16));
}

void led1_ctl(int flag)
{
    if (flag == 1)
    {
        GPIOE->ODR |= (0x1 << 10);
    }
    else if (flag == 0)
    {
        GPIOE->ODR &= (~(0x1 << 10));
    }
}

void led2_ctl(int flag)
{
    if (flag == 1)
    {
        GPIOF->ODR |= (0x1 << 10);
    }
    else if (flag == 0)
    {
        GPIOF->ODR &= (~(0x1 << 10));
    }
}

// LED3控制
void led3_ctl(int flag)
{
    if (flag == 1)
    {
        GPIOE->ODR |= (0x1 << 8);
    }
    else if (flag == 0)
    {
        GPIOE->ODR &= (~(0x1 << 8));
    }
}

main.c

cs 复制代码
#include "led.h"
// 手动封装一个延时函数
void delay_ms(int ms)
{
	int i, j;
	for (i = 0; i < ms; i++)
	{
		for (j = 0; j < 2000; j++)
		{
		}
	}
}
int main()
{
	// 使能GPIO的外设时钟
	*((unsigned int *)0X50000A28) |= (0X3 << 4);
	led1_init();
	led2_init();
	led3_init();

	while (1)
	{
		// LED1亮
		led1_ctl(1);
		led2_ctl(0);
		led3_ctl(0);
		delay_ms(500);
		// LED2亮
		led1_ctl(0);
		led2_ctl(1);
		led3_ctl(0);
		delay_ms(500);
		delay_ms(500);
		// LED3亮
		led1_ctl(0);
		led2_ctl(0);
		led3_ctl(1);
		delay_ms(500);
		delay_ms(500);
	}
	return 0;
}

封装流水灯

相关推荐
板栗焖小鸡8 小时前
Odrive0.5.1-FOC电机控制 arm_cos_f32.cpp arm_sin_f32.cpp代码实现(二)
arm开发·单片机·嵌入式硬件
板栗焖小鸡8 小时前
Odrive0.5.1-FOC电机控制 arm_cos_f32.cpp arm_sin_f32.cpp代码实现(一)
arm开发·单片机·嵌入式硬件
暮云星影21 小时前
十二、buildroot系统 adb登录权限设置
linux·arm开发·adb
钡铼技术物联网关1 天前
ARM分拣机vs传统PLC:实测数据揭示的4倍效率差
大数据·linux·arm开发·人工智能·边缘计算
阿超爱嵌入式1 天前
STM32学习之ARM内核自带的中断
arm开发·stm32·学习
程序员JerrySUN2 天前
深入解析ARM与RISC-V架构的Bring-up核心流程
arm开发·架构·risc-v
ZzxtEcho2 天前
ARM 汇编启动代码详解:从中断向量表到中断处理
汇编·arm开发
钡铼技术物联网关2 天前
工业4.0时代:RK3588边缘工业计算机助力AGV导航升级
linux·arm开发·人工智能·5g·边缘计算
逆鱼_043 天前
ARM-UART
linux·运维·arm开发
钡铼技术物联网关3 天前
ARM架构+CODESYS:解锁嵌入式边缘计算的实时控制新范式
大数据·linux·arm开发·人工智能·边缘计算