- 打卡等级:以坛为家I
- 打卡总天数:224
- 最近打卡:2025-05-07 08:02:46
金牌会员
- 积分
- 1148
|
概念介绍:
IE:中断使能寄存器
EA:总中断允许控制位。
ELVD:低压检测中断允许位。
EADC:A/D 转换中断允许位。
ESn:串行口 n 中断允许位。
ETn:定时/计数器 Tn 的溢出中断允许位。
EXn:外部中断 n 中断允许位。
IE2:中断使能寄存器2
EUSB:USB 中断允许位。
ESPI:SPI 中断允许位。
IP:中断优先级控制寄存器
PXn:外部中断n中断优先级控制位
PTn:定时器n中断优先级控制位
PSn:串口n中断优先级控制位
PADC:ADC中断优先级控制位
PLVD:低压检测中断优先级控制位
IP2:中断优先级控制寄存器2
PSPI:SPI中断优先级控制位
PPWMA:高级PWMA中断优先级控制位
PCMP:比较器中断优先级控制位
PI2C:I2C中断优先级控制位
PUSB:USB中断优先级控制位
IP3:中断优先级控制寄存器3
PRTC:RTC中断优先级控制位
PI2S:I2S中断优先级控制位
串口功能脚切换
P_SW1:
S1_S[1:0]:串口 1 功能脚选择位
P_SW2:
TCON 定时器控制寄存器
TFn:Tn溢出中断标志。Tn被允许计数以后,从初值开始加1计数。
当产生溢出时由硬件将TFn位置“1”,并向CPU请求中断,一直保持到CPU响应中断时,才由硬件清“0”(也可由查询软件清“0”)。
TRn:定时器Tn的运行控制位。该位由软件置位和清零。
当GATE(TMOD.7)=0,TRn=1时就允许T1开始计数,TRn=0时禁止Tn计数。
当GATE(TMOD.7)=1,TRn=1且INT1输入高电平时,才允许Tn计数。
IEn:外部中断n请求源(INT0/P3.2)标志。IEn=1 外部中断n向CPU请求中断,当CPU响应外部中断时,由硬件清“0”IEn(边沿触发方式)。
ITn:外部中断源n触发控制位。ITn=0,上升沿或下降沿均可触发外部中断n。ITn=1,外部中断n程控为下降沿触发方式。
TMOD 定时器模式寄存器
Tn_GATE:控制定时器n,置1时只有在INTn脚为高及TRn控制位置1时才可打开定时器/计数器n。
Tn_CT: 控制定时器n用作定时器或计数器,清0则用作定时器(对内部系统时钟进行计数),置1用作 计数器(对引脚Tn/P3.x外部脉冲进行计数)。
Tn_M1/Tn_M0: 00 -> 16位自动重载模式; 01 -> 16位不自动重载模式; 10 -> 8位自动重载模式; 11 -> 停止工作;
TL0 定时器0低8位寄存器
TL1 定时器1低8位寄存器
TH0 定时器0高8位寄存器
TH1 定时器1高8位寄存器
AUXR 辅助寄存器1
Tnx12:定时器n速度控制位。
0:12T 模式,即 CPU 时钟 12 分频(FOSC/12) 1:1T 模式,即 CPU 时钟不分频分频(FOSC/1)
UART_M0x6:
TnR:定时器n的运行控制位
0:定时器n停止计数 1:定时器n开始计算
Tn_CT:控制定时器n用作定时器或计数器
清0则用作定时器(对内部系统时钟进行计数),置1用作计数器(对引脚T2/P1.2外部脉冲进行计数)。
EXTRAM:
SnBRT:串口波特率
INTCLKO 中断与时钟输出控制寄存器
TnCLKO:定时器n时钟输出控制
0:关闭时钟输出
1:使能 P3.5 口的是定时器 0 时钟输出功能
当定时器 0 计数发生溢出时,P3.5 口的电平自动发生翻转。
WKTCL 掉电唤醒定时器低字节
WKTCH 掉电唤醒定时器高字节
WKTEN:掉电唤醒定时器的使能控制位
0:停用掉电唤醒定时器
1:启用掉电唤醒定时器
T4T3M 定时器4/3 控制寄存器
TnR:定时器n的运行控制位。
0:定时器n 停止计数 1:定时器n 开始计数
Tn_C/T:控制定时器n用作定时器或计数器。
清0则用作定时器(对内部系统时钟进行计数); 置1用作计数器(对引脚T4/P0.6外部脉冲进行计数)。
Tnx12:定时器n速度控制位。
0:12T 模式,即 CPU 时钟 12 分频(FOSC/12)
1:1T 模式,即 CPU 时钟不分频分频(FOSC/1)
TnCLKO:定时器n时钟输出控制
0:关闭时钟输出
1:使能 P0.x 口的是定时器 n 时钟输出功能
T4H 定时器4 高字节
T4L 定时器4 低字节
T3H
T3L
T2H
T2L
TM0PS 定时器0 时钟预分频寄存器
TM1PS
TM2PS
TM3PS
TM4PS
TimerN :PTn,PTnH TFn ETn
SnCON : 串口n控制寄存器
SnTI:串口n发送完成中断请求标志。需要软件清零。
SnRI:串口n接收完成中断请求标志。需要软件清零。
SnRB8:
SnTB8:
SnREN:
SnSM2:
SnSM1:
SnSM0:
例子分析:
1. 设置波特率
void SetTimer2Baudraye(u32 dat)
{
T2R = 0; //Timer stop
T2_CT = 0; //Timer2 set As Timer
T2x12 = 1; //Timer2 set as 1T mode
T2H = (u8)(dat / 256);
T2L = (u8)(dat % 256);
ET2 = 0; //禁止中断
T2R = 1; //Timer run enable
}
2.同上
void UART1_config(u8 brt)
{
/*********** 波特率使用定时器2 *****************/
if(brt == 2)
{
S1BRT = 1; //S1 BRT Use Timer2;
SetTimer2Baudraye(Baudrate1);
}
/*********** 波特率使用定时器1 *****************/
else
{
TR1 = 0;
S1BRT = 0; //S1 BRT Use Timer1;
T1_CT = 0; //Timer1 set As Timer
T1x12 = 1; //Timer1 set as 1T mode
TMOD &= ~0x30;//Timer1_16bitAutoReload;
TH1 = (u8)(Baudrate1 / 256);
TL1 = (u8)(Baudrate1 % 256);
ET1 = 0; //禁止中断
TR1 = 1;
}
/*************************************************/
SCON = (SCON & 0x3f) | 0x40; //UART1模式, 0x00: 同步移位输出, 0x40: 8位数据,可变波特率, 0x80: 9位数据,固定波特率, 0xc0: 9位数据,可变波特率
// PS = 1; //高优先级中断
ES = 1; //允许中断
REN = 1; //允许接收
P_SW1 &= 0x3f;
P_SW1 |= 0x00; //UART1 switch to, 0x00: P3.0 P3.1, 0x40: P3.6 P3.7, 0x80: P1.6 P1.7, 0xC0: P4.3 P4.4
B_TX1_Busy = 0;
TX1_Cnt = 0;
RX1_Cnt = 0;
}
3.接收数据
void UART1_int (void) interrupt 4
{
if(RI)
{
RI = 0;
RX1_Buffer[RX1_Cnt] = SBUF;
if(++RX1_Cnt >= UART1_BUF_LENGTH) RX1_Cnt = 0;
}
if(TI)
{
TI = 0;
B_TX1_Busy = 0;
}
}
4.主逻辑
void main(void)
{
WTST = 0; //设置程序指令延时参数,赋值为0可将CPU执行指令的速度设置为最快
EAXFR = 1; //扩展寄存器(XFR)访问使能
CKCON = 0; //提高访问XRAM速度
P0M1 = 0x30; P0M0 = 0x30; //设置P0.4、P0.5为漏极开路(实验箱加了上拉电阻到3.3V)
P1M1 = 0x30; P1M0 = 0x30; //设置P1.4、P1.5为漏极开路(实验箱加了上拉电阻到3.3V)
P2M1 = 0x3c; P2M0 = 0x3c; //设置P2.2~P2.5为漏极开路(实验箱加了上拉电阻到3.3V)
P3M1 = 0x50; P3M0 = 0x50; //设置P3.4、P3.6为漏极开路(实验箱加了上拉电阻到3.3V)
P4M1 = 0x3c; P4M0 = 0x3c; //设置P4.2~P4.5为漏极开路(实验箱加了上拉电阻到3.3V)
P5M1 = 0x0c; P5M0 = 0x0c; //设置P5.2、P5.3为漏极开路(实验箱加了上拉电阻到3.3V)
P6M1 = 0xff; P6M0 = 0xff; //设置为漏极开路(实验箱加了上拉电阻到3.3V)
P7M1 = 0x00; P7M0 = 0x00; //设置为准双向口
UART1_config(2); // 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
EA = 1; //允许全局中断
PrintString1("STC32G UART1 Test Programme!\r\n"); //UART1发送一个字符串
while (1)
{
if((TX1_Cnt != RX1_Cnt) && (!B_TX1_Busy)) //收到数据, 发送空闲
{
SBUF = RX1_Buffer[TX1_Cnt];
B_TX1_Busy = 1;
if(++TX1_Cnt >= UART1_BUF_LENGTH) TX1_Cnt = 0;
}
}
}
|
|