day4 pcb板子电灯小实验

news/2024/7/5 4:53:59

三个小灯轮流转。好似华清过圣诞

main.c

#include "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++);
}


int main()
{
	*((volatile int*)0x50000A28) |= (0b11 << 4);
	led_init(GPIOE,10);
	led_init(GPIOF,10);
	led_init(GPIOE,8);
	while(1)
	{
		led_on(GPIOE,10);
		delay_ms(500);
		led_off(GPIOE,10);
		delay_ms(500);
		led_on(GPIOF,10);
		delay_ms(500);
		led_off(GPIOF,10);
		delay_ms(500);
		led_on(GPIOE,8);
		delay_ms(500);
		led_off(GPIOE,8);
		delay_ms(500);
	}
	return 0;
}

led.h

#ifndef __LED_H__
#define __LED_H__

typedef struct{
	unsigned int MODER;
	unsigned int OTYPER;
	unsigned int OSPEEDR;
	unsigned int PUPDR;
	unsigned int IDR;
	unsigned int ODR;
}gpio_t;

#define GPIOE ((volatile gpio_t*)0x50006000)
#define GPIOF ((volatile gpio_t*)0x50007000)

int my_strlen(char*);
char *my_strcpy(char*,char*);
char *my_strcat(char*,char*);

void led_init(volatile gpio_t*,int);
void led_on(volatile gpio_t*,int);
void led_off(volatile gpio_t*,int);

#endif

led.c

#include "led.h"
int my_strlen(char *s1){
	
	int len = 0;
	while(*s1){
		len++;	
	}
	return len;

}

char *my_strcpy(char *s1, char *s2){

	int i = 0;
	while(*s2){
	
		s1[i] = s2[i];
		i++;
	}
	s1[i] = '\0';
	return s1;
}

char *my_strcat(char *s1,char *s2){

	int i = 0;
	int len1 = my_strlen(s1);
	int len2 = my_strlen(s2);
	for(int i = 0; i <= len2; i++){
		s1[len1 + i + 1] = s2[i];
	}
	s1[i] = '\0';
	return s1;
}

void led_init(volatile gpio_t* gpio,int pin){
 

	gpio->MODER &= ~(0b11 << pin * 2);
	gpio->MODER |= (0x1 << pin * 2);
	gpio->OTYPER &= ~(0x1 << pin);
	gpio->OSPEEDR &= ~(0b11 << pin * 2);
	gpio->PUPDR &= ~(0b11 << pin * 2);

}

void led_on(volatile gpio_t* gpio,int pin){
	
	gpio->ODR |= (0x1 << pin);
}

void led_off(volatile gpio_t* gpio,int pin){

	gpio->ODR &= ~(0x1 << pin);

}

void gpio_init(volatile gpio_t* gpio,int num){

	for(int i = 0; i < num; i++){
		gpio = (volatile gpio_t*)(0x50002000 + 0x1000 * num); 
	}
}

void operate_pin(volatile gpio_t* gpio,int pin,int operation_code){
	
	gpio->MODER &= ~(0b11 << pin * 2);
	gpio->MODER |= (0x1 << pin * 2);
	gpio->OTYPER &= ~(0x1 << pin);
	gpio->OSPEEDR &= ~(0b11 << pin * 2);
	gpio->PUPDR &= ~(0b11 << pin * 2);
	if( operation_code == 1){
		gpio->ODR |= (0x1 << pin);
	}else{
		gpio->ODR &= ~(0x1 << pin);
	}
}


http://lihuaxi.xjx100.cn/news/1305222.html

相关文章

HOT35-LRU缓存

leetcode原题链接&#xff1a;LRU缓存 题目描述 请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结构。 实现 LRUCache 类&#xff1a; LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存int get(int key) 如果关键字 key 存在于缓存中&…

【算法】Prime Pairs With Target Sum 和等于目标值的质数对

文章目录 Prime Pairs With Target Sum 和等于目标值的质数对问题描述&#xff1a;分析代码 Tag Prime Pairs With Target Sum 和等于目标值的质数对 问题描述&#xff1a; 给你一个整数 n 。如果两个整数 x 和 y 满足下述条件&#xff0c;则认为二者形成一个质数对&#xff…

cf1406 C 树的重心

题意&#xff1a;https://www.luogu.com.cn/problem/CF1406C 思路&#xff1a;首先需要知道树的重心的一些性质&#xff0c;可以看看这篇文章 https://zhuanlan.zhihu.com/p/357938161 那么这题就是找出重心&#xff0c;如果有两个就将他的一个子树移到另一个重心上。 /*ke…

Elasticsearch实战(二十四)---ES数据建模一对多模型Nested结构

Elasticsearch实战—ES数据建模一对多模型Nested结构 文章目录 Elasticsearch实战---ES数据建模一对多模型Nested结构1.ES 一对多模型Nested 结构模型实战2.ES字段查询2.1 非Nested 错误结构及错误查询2.2 Nested结构&#xff0c;正确查询 3.Nested结构原理 我们如何把Mysql的模…

初步学习使用SpringBoot框架

对于SpringBoot框架介绍大家可以看看这个这篇文章&#xff0c;SpringBoot优缺点以及如何安装使用 以下我是按照老师给的安装方法进行安装使用SpringBoot框架&#xff1a; 大家安装SpringBoot框架时候&#xff0c;最好安装3.0以下的&#xff0c;不然需要对应较高版本的JDK版本&…

快速排序的三路划分方法和归并排序的递归和非递归实现

目录 快速排序的三路划分方法 归并排序的递归实现 归并排序的非递归实现 快速排序的三路划分方法 首先快排的时间复杂度为O(N*logN)&#xff0c;空间复杂度O(logN),不稳定。 三路划分&#xff1a;将数据分为三份&#xff1b;可以提高当数据中出现多个重复数字时的效率。 …

有没有免费提取音频的软件,分享几个给大家!

在日常生活中&#xff0c;我们经常遇到需要从视频中提取音频的情况&#xff0c;无论是为了制作音频片段、录制语音笔记还是进行后期编辑。本文将介绍三种免费提取音频的方法&#xff0c;分别是记灵在线工具、PR&#xff08;Adobe Premiere Pro&#xff09;和剪映。通过这些方法…

【新版系统架构】第九章-软件可靠性基础知识

软考-系统架构设计师知识点提炼-系统架构设计师教程&#xff08;第2版&#xff09; 第一章-绪论第二章-计算机系统基础知识&#xff08;一&#xff09;第二章-计算机系统基础知识&#xff08;二&#xff09;第三章-信息系统基础知识第四章-信息安全技术基础知识第五章-软件工程…