网站大量收购闲置独家精品文档,联系QQ:2885784924

串口协议栈.doc

  1. 1、本文档共31页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
串口协议栈 篇一:协议栈中的串口操作 ZigBee学习之42——协议栈中的串口操作 如果要使用协议栈中提供的串口,则需要定义HAL_UART和HAL_UART TRUE【hal_board_cfg.h】。首先初始化串口,在主函数中调用HalDriverInit()时,在函数中初始化串口,主要是配置管脚和DMA通道。然后在osal_start_system()开始系统后,会调用Hal_ProcessPoll ()来读取时间和串口, void Hal_ProcessPoll () { HalTimerTick(); #if (defined HAL_UART) amp;amp; (HAL_UART == TRUE) HalUARTPoll(); #endif } //来看下串口poll函数,我们只看UART0的,因为我的开发板使用这个串口 void HalUARTPoll( void ) { #if ( HAL_UART_0_ENABLE | HAL_UART_1_ENABLE ) static uint8 tickShdw; uartCfg_t *cfg; uint8 tick; #if HAL_UART_0_ENABLE //当发生串口接收中断时cfg0就会改变,如果串口没有数据输入cfg0为空,当接收到数据时cfg0将在串口中断服务程序中被改变 if ( cfg0 ) { cfg = cfg0; } #endif // Use the LSB of the sleep timer (ST0 must be read first anyway). //系统上电后,睡眠定时器就会自动启动做自增计数ST0即睡眠定时器启动到现在计算值的最低8位 tick = ST0 - tickShdw; tickShdw = ST0; //要注意接下来的是个循环 do { if ( cfg-txTick tick ) { cfg-txTick -= tick; } else { cfg-txTick = 0; } if ( cfg-rxTick tick ) { cfg-rxTick -= tick; } else { cfg-rxTick = 0; } //是使用DMA方式还是使用中断方式 #if HAL_UART_ISR #if HAL_UART_DMA if ( cfg-flag amp; UART_CFG_DMA ) { pollDMA( cfg ); } else #endif { pollISR( cfg ); //中断方式 static void pollISR( uartCfg_t *cfg ) { //如果串口没有接收到数据,也就是说没有发生过串口接收中断,那么cfg应为是为空的,则cnt=0 //如果发生了串口中断,则cnt计算出串口缓存中还有多少数据没有读出,这个缓存并不是硬件寄存器的缓存,而是程序中开辟一段空间 uint8 cnt = UART_RX_AVAIL( cfg ); if ( !(cfg-flag amp; UART_CFG_RXF) ) { //这里是针对流控制的,如果又有新的数据接收到了那么就要重置超时时间(超时 时间由睡眠定时器来控制),而且需要把已经读出的数据数目减去! // If anything received, reset the Rx idle timer. if ( cfg-rxCnt != cnt ) { cfg-rxTick = HAL_UART_RX_IDLE; cfg-rxCnt = cnt; } /* It is necessary to stop Rx flow in advance of a full Rx buffer because * bytes can keep coming while sending H/W fifo flushes. */ //当接收缓存超过安全界限的时候停止RX流 if ( cfg-rxCnt = (cfg-rxMax - SAFE_RX_MIN) ) { RX_STOP_FLOW( cfg ); } //关于安全界限,在程序中有下面一段: /* Need to leave enough of the Rx buffer free to handle the incomin g bytes * after asserting flow control, but before the transmitter has obeyed i t. * At the max

文档评论(0)

精品文档 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档