void initUart(void){ CLKCONCMD &= ~0x40; //设置系统时钟源为 32MHZ 晶振 while(CLKCONSTA & 0x40); //等待晶振稳定 CLKCONCMD &= (~0x47); //设置系统主时钟频率为 32MHZ PERCFG = 0x00; // 设置外设控制为 P0 P0SEL = 0x3C; // 选择 P0_2,P0_3,P0_4,P0_5 作为串口 P2DIR &= (~0XC0); //P0 优先作为 UART0 U0CSR |= 0x80; //UART 方式 U0GCR |= 11; U0BAUD |= 216; //波特率设为 115200 UTX0IF = 1; //UART0 TX 中断标志初始置位 1 U0CSR |= 0x40; //允许中断接收 IEN0 |= 0x84; //开总中断,接收数据}//串口发送字符串 data - 数据指针 len - 数据长度void uartSendString(u8 *data, u8 len){ u8 j; for(j = 0; j < len; j++) { U0DBUF = *data++; // 填充数据到串口数据寄存器 while (UTX0IF == 0); // 等待串口发送完毕 UTX0IF = 0; // 将串口中断标志置 0,准备下一次的发送 }}//接收函数以#结束,最大接收64byte数据#pragma vector = URX0_VECTOR __interrupt void UART0_ISR(void){ URX0IF = 0; //清除中断 tmp = U0DBUF; //接收数据 if((tmp != '#') && (recSta < 0x40)) //判断是否以#结尾的数据,或者接收的
时间: 2024-02-14 21:24:18 浏览: 24
这段代码定义了两个函数,一个是"initUart",用于初始化串口;另一个是"uartSendString",用于向串口发送字符串。
在"initUart"函数中,首先设置系统时钟源为32MHZ晶振,并等待晶振稳定。然后设置系统主时钟频率为32MHZ,将外设控制设置为P0,选择P0_2、P0_3、P0_4和P0_5作为串口,将P0优先作为UART0。接着设置UART方式,将波特率设为115200,将UART0 TX中断标志初始置为1,允许中断接收,开总中断,接收数据。
在"uartSendString"函数中,使用一个for循环依次向串口发送数据。每次发送完毕后,使用while循环等待串口发送完成,并将串口中断标志置0,准备下一次发送。
最后,定义了一个UART0中断服务函数"UART0_ISR",当有数据接收时,将接收数据存储到"tmp"变量中,并判断是否以#结尾的数据或者接收的数据长度是否超过了64byte。如果接收到的数据符合要求,则将数据存储到接收缓冲区"recBuf"中。
相关问题
解释这段代码#include "ioCC2530.h" #include <string.h> #define LED1 P1_0 #define uint16 unsigned short #define uint32 unsigned long #define uint unsigned int unsigned int flag,counter=0; unsigned char s[8]; void InitLED() { P1SEL &= ~0x01; P1DIR |= 0x01; LED1 = 0; } void adc_Init(void) { APCFG |= 1; P0SEL |= 0x01; P0DIR &= ~0x01; } uint16 get_adc(void) { uint32 value; ADCIF = 0; ADCCON3 = (0x80 | 0x10 |0x00); while(!ADCIF) { ; } value = ADCH; value = value<<8; value |=ADCL; value = (value * 330); value = value >> 15; return (uint16)value; } void initUART0(void) { PERCFG = 0x00; P0SEL = 0x3c; U0CSR |= 0x80; U0BAUD = 216; U0GCR = 10; U0UCR |=0x80; UTX0IF = 0; EA = 1; } void initTimer1() { CLKCONCMD &= 0x80; T1CTL = 0x0E; T1CCTL0 |= 0x04; T1CC0L = 50000 & 0xFF; T1CC0H = ((50000 & 0xFF00) >> 8); T1IF = 0; T1STAT &= ~0x01; TIMIF &= ~0x40; IEN1 |= 0x02; EA = 1; } void UART0SendByte(unsigned char c) { U0DBUF = c; while(!UTX0IF); UTX0IF = 0; } void UART0SendString(unsigned char *str) { while(*str != '\0') { UART0SendByte(*str++); } } void Get_val() { uint16 sensor_val; sensor_val = get_adc(); s[0] = sensor_val/100+'0'; s[1] = '.'; s[2] = sensor_val/10%10+'0'; s[3] = sensor_val%10+'0'; s[4] = 'V'; s[5] = '\n'; s[6] = '\0'; } #pragma vector = T1_VECTOR __interrupt void T1_ISR(void) { EA = 0; counter++; T1STAT &= ~0x01; EA = 1; } void main(void) { InitLED(); initTimer1(); initUART0(); adc_Init(); while(1) { if(counter>=15) { counter=0; LED1 = 1; Get_val(); UART0SendString("光照传感器电压值"); UART0SendString(s); LED1 = 0; } } }
这段代码是一段基于 TI CC2530 芯片的嵌入式程序代码,其主要功能是读取光照传感器的电压值,并通过串口发送给外部设备。下面是主要函数的功能和作用:
- InitLED(): 初始化 LED 灯,使其可以被控制。
- adc_Init(): 初始化 ADC 模块,用于读取光照传感器的电压值。
- get_adc(): 读取 ADC 的值,并将其转换为电压值。
- initUART0(): 初始化 UART0 模块,用于与外部设备进行串口通信。
- UART0SendByte(): 通过 UART0 发送一个字节的数据。
- UART0SendString(): 通过 UART0 发送一个字符串的数据。
- Get_val(): 获取光照传感器的电压值,并将其转换为字符串形式。
- T1_ISR(): 定时器 1 的中断服务程序。
在 main 函数中,主要是通过定时器模块来控制 LED 灯的闪烁,并定时读取光照传感器的电压值,并将其通过串口发送给外部设备。
void InitUart(uchar Ux,uchar GCR,uchar BAUD) { if(Ux == USART0) { //端口设置 PERCFG = 0x00; //备用位置1 SFR寄存器位PERCFG.U0CFG选择是否使用备用位置1 或备用位置 2。 P0SEL = 0x0c; //根据外设 I/O 引脚映射设置P0_2(接收),P0_3(发送)为外设引脚 1100 P2DIR &= ~0xc0; //USART0为第一优先级 1100 0000 //UART设置 U0CSR |= 0x80; //USART模式选择,设置为UART方式 1000 0000 7位描述:USART 0 控制和状态 U0GCR |= GCR; //GCR 11 BAUD 216 U0BAUD |= BAUD; //U0GCR的0-4位:波特率指数值 U0BAUD的0-7位:波特率小数部分的值 UTX0IF = 0; //UART0 TX传送中断标志初始置位0 U0CSR |= 0X40; //UART接收器使能。1: 接收器使能 0100 0000 IEN0 |= 0x84; //开总中断,接收中断 1000 0100 第2位描述:USART0 RX中断使能 第7位描述:1: 通过设置对应的使能位将每个中断源分别使能和禁止 } else if(Ux == USART1) { //端口设置 PERCFG = 0x00; //备用位置1 SFR寄存器位PERCFG.U0CFG选择是否使用备用位置1 或备用位置 2。 P0SEL |= 0x30; //根据外设 I/O 引脚映射设置P0_5(接收),P0_4(发送)为外设引脚 P2DIR |= 0x10; //USART1为第一优先级 //UART设置 U1CSR |= 0x80; //USART模式选择,设置为UART方式 1000 0000 7位描述:USART 0 控制和状态 U1GCR = GCR; U1BAUD = BAUD; //根据手册,设置波特率 UTX1IF = 0; //UART1 TX中断标志初始置位0 IEN0 |= 0x84; } }
这段代码是用于初始化UART通信的函数,根据传入的参数Ux的不同,来初始化不同的串口通信模块。当Ux为USART0时,将P0_2定义为UART接收引脚,P0_3定义为UART发送引脚;当Ux为USART1时,将P0_5定义为UART接收引脚,P0_4定义为UART发送引脚。
下面是该函数的执行过程:
1. 接收传入的参数Ux,判断其值是否为USART0。
2. 若Ux的值为USART0,则进入if语句中,执行PERCFG = 0x00;设置备用位置1,SFR寄存器位PERCFG.U0CFG选择是否使用备用位置1或备用位置2;执行P0SEL = 0x0c;将P0_2和P0_3设置为外设引脚;执行P2DIR &= ~0xc0;将USART0设置为第一优先级;执行U0CSR |= 0x80;将USART模式选择为UART方式;执行U0GCR |= GCR;U0BAUD |= BAUD;分别设置波特率指数值和波特率小数部分的值;执行UTX0IF = 0;将UART0 TX传送中断标志初始置为0;执行U0CSR |= 0X40;使能UART接收器;执行IEN0 |= 0x84;开启总中断和接收中断,使能USART0 RX中断。
3. 若Ux的值不为USART0,继续判断其值是否为USART1。
4. 若Ux的值为USART1,则进入else if语句中,执行PERCFG = 0x00;设置备用位置1,SFR寄存器位PERCFG.U0CFG选择是否使用备用位置1或备用位置2;执行P0SEL |= 0x30;将P0_5和P0_4设置为外设引脚;执行P2DIR |= 0x10;将USART1设置为第一优先级;执行U1CSR |= 0x80;将USART模式选择为UART方式;执行U1GCR = GCR;U1BAUD = BAUD;分别设置波特率指数值和波特率小数部分的值;执行UTX1IF = 0;将UART1 TX传送中断标志初始置为0;执行IEN0 |= 0x84;开启总中断和接收中断,使能USART1 RX中断。
5. 若Ux的值既不为USART0也不为USART1,则函数执行结束。
这样,UART初始化函数就根据传入的参数Ux完成了对相应的串口通信模块的初始化。