开启Ai8051U学习之路!
从《8051U深度入门到32位51大型实战教学视频》开始第一集在此之前,看了些图书,做了功课的。但经老师推荐来到本站后,才发现目前的51单片机与书本上的介绍已有了天翻地覆的提升。听了本集课程,感受到了Ai8051u的强大功能。也感受到了新型高速单片机带来的极致体验效果。我希望在这里,通过国芯论坛,通过冲哥的视频教程,能学习到更好的硬件编程方法,和创造更有实用价值的制作。
第二集
工欲善其事,必先利其器。
官方推出的实验箱,就是学习掌握Ai8051U这块芯片的利器!
第三集 点亮第一个LED
本集开启实战模式
GPIO即通用输入输出端口的简称,可以通过软件来读取其输入电平或者控制它输出高低电平。1为高电平,0为低电平。
利用软件建立工程,在keil软件下编辑完代码以后,编译生成.hex文件,我们将这个.hex文件通过ISP下载到芯片中。
如果LED不亮的话考虑引脚是否正确。
检查是否P2口。
第四集 USB不停电下载
实现自动下载的好处是不需要断电进行下载。
通过使用特殊功能寄存器IAP-CONTR,当用户向此寄存器写入0x06,即可实现软件复位到系统区,进而实现不断电就可进行ISP下载。
需要将lib库添加到代码包里。
下载时,串口变成了USB—CDC模式
第五集 C语言基础
USB CDC 串口实现 printf 函数
#define PRINTF_HID //printf输出直接重定向到USB HID接口
int printf_hid (const char *fmt, ...);
#if defined PRINTF_SEGLED
#define printfSEG7_ShowString
#elif defined PRINTF_HID
#define printfprintf_hid //#define替换名被替换名
#endif
其他讲解的都是标准C
第六集 I/O输入输出
General Purpose I/O Ports:输入/输出端口
引脚的状态(高/低电平:1/0)VCC/GND
按键输入检测
(1) 硬件防抖:① 自身特性,导致触电断开、闭合时据不完全统计会有5-10毫秒的接触不良(需要做按键消抖处理);② 利用电容特性,按键两端并联电容(常用0.1-10uf);③ 设计RS触发器电路;(2) 软件防抖:① 通过延时消抖(20ms左右)
第七集 定时器中断
Ai8051U 系列单片机内部设置了 6 个 24 位定时器/计数器(8 位预分频+16 位计数)。
6 个 16 位定时器 T0、T1、T2、T3、T4 和 T11 都具有计数方式和定时方式两种工作方式。
https://www.stcaimcu.com/data/attachment/forum/202502/03/130359bjddxa07aqjuszxr.png
在本集中,冲哥通过3个任务深入浅出地介绍了STC单片机定时器的基本应用。
见代码:
#include "ai8051u.h" //调用头文件
#include "stc32_stc8_usb.h" //调用头文件
#include "intrins.h" //d调用头文件
#define u8 unsigned char // 8位无符号变量(0-255)
#define u16 unsigned int // 16位无符号变量(0-65535)
u8 state = 0; // 初始状态
u8 Run_State = 0; // 运行状态
char *USER_DEVICEDESC = NULL;
char *USER_PRODUCTDESC = NULL;
char *USER_STCISPCMD = "@STCISP#";
void Delay20ms(void) //@24.000MHzDelay20ms();
{
unsigned long edata i;
_nop_();
_nop_();
i = 119998UL;
while (i)
i--;
}
void Timer0_Init(void); // 3秒@24.000MHz //函数声明
void main(void)
{
int count = 1; // 按键计数变量
WTST = 0;// 设置程序指令延时参数,赋值为0可将CPU执行指令的速度设置为最快
EAXFR = 1; // 扩展寄存器(XFR)访问使能
CKCON = 0; // 提高访问XRAM速度
usb_init(); // USB CDC 接口配置
IE2 |= 0x80; // 使能USB中断
EA = 1; // IE |= 0X80;
P40 = 0;
while (DeviceState != DEVSTATE_CONFIGURED)
; // 等待USB完成配置
while (1)
{
if (bUsbOutReady) // 如果接收到了数据
{
usb_OUT_done(); //
}
// 任务1:
if (P32 == 0) // 判断P32按钮是否按下
{
Delay20ms(); // 延时20ms消抖
if (P32 == 0)
{
printf("按键按下次数\xfd:%d 次\r\n", (int)count);
count++;
while (P32 == 0)
; // 等待P32松开
}
}
// 任务2:灯按一下点亮三秒后熄灭。
if (P32 == 0) // 判断P32按钮是否按下
{
Delay20ms(); // 延时20ms消抖
if (P32 == 0)
{
printf("按键按下次数\xfd:%d 次\r\n", (int)count);
count++;
P00 = 0;
Timer0_Init();
while (P32 == 0)
; // 等待P32松开
}
}
// 任务3:救护车灯控制器,按下报警按钮,红蓝交替闪烁(LED1和LED2表示红和蓝灯),再按一下报警按钮,红蓝灯停止。
if (P32 == 0) // 判断P32按钮是否按下
{
Delay20ms(); // 延时20ms消抖
if (P32 == 0)
{
Run_State = !Run_State; // 运行状态取反
if (Run_State == 1) // 运行
{
Timer0_Init();
}
else
{
TR0 = 0; // 关闭定时器
P00 = 1;
P01 = 1;
}
while (P32 == 0)
; // 等待P32松开
}
}
}
}
void Timer0_Init(void) // 500毫秒@24.000MHz
{
TM0PS = 0x0F; // 设置定时器时钟预分频 ( 注意:并非所有系列都有此寄存器,详情请查看数据手册 )
AUXR &= 0x7F; // 定时器时钟12T模式
TMOD &= 0xF0; // 设置定时器模式
TL0 = 0xDC; // 设置定时初始值
TH0 = 0x0B; // 设置定时初始值
TF0 = 0; // 清除TF0标志
TR0 = 1; // 定时器0开始计时
ET0 = 1; // 使能定时器0中断
}
void Timer0_Isr(void) interrupt 1 // 3秒执行一次
{
state = !state;
P00 = state;
P01 = !state;
}
第八集 定时器周期性调度任务
本讲继续深入讲解定时器的应用,主要是用于周期性的调度任务。通过利用定时器中断,可极大减少单片机资源消耗,避免空循环浪费资源。
同样,冲哥还是用了3个任务来详细讲解:
在本集中,还重点学习了代码的模块划分。
页:
[1]