LED简介
在ARM210中,因为是统一编址,所以可以通过控制对应的寄存器去控制相应的管脚,那么,在51单片机中要怎么操作呢?
在单片机中,同样是通过操作寄存器:
51单片机是8位的,用1位来控制1个LED即可。210是用4位来控制1个引脚。
先写c文件,然后生成hex文件。hex文件格式是可以烧写到单片机中,被单片机执行的一种文件格式,生成Hex文件的方式有很多种,可以通过不同的编译器将C程序或者汇编程序编译生成hex。
查看原理图
在210中,外设的连接路线基本上是已经确定好的,哪个外设连接了哪些引脚,这些引脚对应的是哪个寄存器,都能在手册中找到,之后,通过操作对应的寄存器来实现对外设的控制。
我在学习51单片机的时候,LED的连接并没有确定,只知道LED的阳极引脚分别为JR1-JR8,引出在J12排针上。
LED的点亮比较容易,只要通电即可,此处是共阴极接地,那么,只要阳极接上高电平,就能点亮对应的LED。
查看数据手册
根据210的学习,通常是使用GPIO来控制LED的,不知道51是怎么控制的?
我自己去找相关的寄存器,并没有明确说哪些引脚是控制LED的。
理论上,连接任意的GPIO都可以。
本文将8个LED灯连接到了P0端口,同时,给锁存器的LE置高电平,让它工作在跟随状态。
实际中的开发板,不会让自己连线的,一般都是已经焊接好了。
端口操作方式
使用一款单片机或者芯片时,需要知道它是如何来操作IO端口的。
我在学习210时,是不同的寄存器控制着相应的端口,端口包含了若干个引脚。赋值时,是通过向寄存器地址所对应的内存中写入控制数据,比如:
*port0Reg = 0x1001F3F0
不过,在51中,虽然也是通过寄存器来控制,但是51单片机已经定义好了相应的端口,直接给端口赋值即可完成引脚控制。
51的端口和引脚定义就在reg51.h头文件中,所以写51代码时,需要引入该头文件。
我的代码
功能1:点亮所有的LED,然后熄灭所有的LED,接着又点亮所有的LED。依次循环。
/** *@author Timi *@date 2022.07.13 *@version 1.0 */ #include <reg51.h> void LedFlash(); void delay(); void main(void) { LedFlash(); } /** *@brief 所有LED闪烁 *@param[in] *@param[out] *@return */ void LedFlash() { while(1) { P0 = 0XFF; delay(); P0 = 0X00; delay(); } } /** *@brief 延时 *@param[in] *@param[out] *@return */ void delay() { int i = 0, j = 0; for(i;i<30000;i++) { for(j;j<30000;j++); } }
功能2:点亮对应的LED灯。
/** *@file bitlightled.c *@author Timi *@date 2022.07.13 *@version 1.0 */ #include <reg51.h> enum ledsNum { LED0, LED1, LED2, LED3, LED4, LED5, LED6, LED7 }; void BitLightLed(int ledNum); void LedFlash(); void Delay(); //程序入口 void main(void) { BitLightLed(LED3); } /** *@brief 指定LED点亮 *@param[in] LED的编号,0—7 *@param[out] *@return */ void BitLightLed(int ledNum) { if(ledNum < 0 || ledNum >7) { LedFlash(); } else { P0 = (0x1 << ledNum); } } /** *@brief 所有LED闪烁 *@param[in] *@param[out] *@return */ void LedFlash() { while(1) { P0 = 0XFF; delay(); P0 = 0X00; delay(); } } /** *@brief 延时 *@param[in] *@param[out] *@return */ void Delay() { int i = 0, j = 0; for(i;i<20000;i++) { for(j; j < 20000; j++); } }
优化总结
在流水灯代码设计中,可以使用移位运算来优化代码。不做赘述。