USMART移植过程:
1.将usmart组件添加到工程文件夹下,在选项和组办理即中,装备好头文件途径和组文件。
2.usmart.c首要包括两个函数void usmart_init(u8 sysclk)和void usmart_scan(void),第一个函数里有个条件编译#if USMART_ENTIM2_SCAN==1,这个在usmart.h里设置。这个宏界说初始化定时器2,本试验在定时器2的中止处理函数中履行usmart_dev.scan();进行行usmart扫描,为了便于移植,中止初始化及处理函数写在了usamrt.c里,time.c里边的初始化和终端处理被注释掉了。
3.特别留意:这个组件运用串口发送调试函数,usart.c函数也修正了,我在测验中编译没问题了,可是调试没成果,便是这个函数没有批改过来导致的。
- //V1.4修正阐明
- //1,修正串口初始化IO的bug
- //2,修正了USART_RX_STA,使得串口最大接纳字节数为2的14次方
- //3,添加了USART_REC_LEN,用于界说串口最大答应接纳的字节数(不大于2的14次方)
- //4,修正了EN_USART1_RX的使能方法
- #ifEN_USART1_RX//假如使能了接纳,在usart.h里界说
- //串口1中止服务程序
- //留意,读取USARTx->SR能防止不可思议的过错
- //u8USART_RX_BUF[64];//接纳缓冲,最大64个字节.
- u8USART_RX_BUF[USART_REC_LEN];//接纳缓冲,最大USART_REC_LEN个字节.
- //接纳状况
- //bit7,接纳完结标志
- //bit6,接纳到0x0d
- //bit5~0,接纳到的有效字节数目
- u16USART_RX_STA=0;//接纳状况符号
- voidUSART1_IRQHandler(void)
- {
- u8res;
- if(USART1->SR&(1<<5))//接纳到数据
- {
- res=USART1->DR;
- if((USART_RX_STA&0x8000)==0)//接纳未完结,由本来的80改为8000
- {
- if(USART_RX_STA&0x4000)//接纳到了0x0d,由本来的40改为4000
- {
- if(res!=0x0a)USART_RX_STA=0;//接纳过错,重新开始
- elseUSART_RX_STA|=0x8000;//接纳完结了,由本来的80改为8000
- }else//还没收到0X0D
- {
- if(res==0x0d)USART_RX_STA|=0x4000;//由本来的40改为4000
- else
- {
- USART_RX_BUF[USART_RX_STA&0X3F]=res;
- USART_RX_STA++;
- if(USART_RX_STA>(USART_REC_LEN-1))USART_RX_STA=0;//接纳数据过错,重新开始接纳
- }
- }
- }
- }
- }
- #endif
4.在主函数中添加好usmart.h头文件、参加usmart_dev.init(72);初始化USMART
5.在usmart.h 中设置USMART_ENTIM2_SCAN==1
6.在usmart_config.c里添加想要调用的函数,这儿的添加函数很简单,只要把函数地点头文件添加进来,并把函数名按上图所示的方法添加即可,默许咱们添加了两个函数:delay_ms和delay_us。如下:
详细参阅见usmart V2.4运用阐明。
留意一个问题:#if和#ifdef的差异
(1)
#if 常量表达式
程序。。。//当常量表达式非零时分才编译本段
#endif
(2)
#ifdef 标识符 //标识符通过#define界说过不管零还对错零都编译
程序。。。
#else
程序。。。
#endif