sdsd5

    1. COM_Open handle 0xD28173C0, access 0x0, share 0x3 分析1:个人通过对SDIO驱动[支持电源管理]、与普通的流驱动[不支持电源管理]发现,支持电源管理的驱动会有两次OPEN,一次CLOSE,这与COM2我跟踪到的情况是一致,而普通的流驱动则没有。所以我得到的结果是Access=0x0的,是系统调用用于查询相关属性,如设备支持几种电源状态。不知道我这种理解是否正确,因为COM的ICLASS并没有配置成支持电源管理。 分析2:串口源代码都是MS的,没有修改过,因为我发现在COM_Open时,有代码调用HWOpen,并增加记数:         if ( !pHWObj->pFuncTbl->HWOpen(pSerialHead->pHWHead) ) {             RETAILMSG (1, (TEXT("HW Open failed.\r\n")));             goto OpenFail;         }        ....        ++(pSerialHead->OpenCnt); 而关闭时,HWClose未被调用,代码如下:         // If we are closing the last open handle, then close PDD also         if ( !pSerialHead->OpenCnt ) {// 跟踪到OpenCnt = 2 即我前面提到的Open两次,才执行一次关闭             RETAILMSG (myset, (TEXT("About to call HWClose\r\n")));             if ( pHWObj )                 pHWObj->pFuncTbl->HWClose(pSerialHead->pHWHead);             RETAILMSG (myset, (TEXT("Returned from HWClose\r\n"))); 因此,在我未通过应用程序打开COM2口时,这时一旦有数据向COM2[DMA_Enable]发送时,过段时间整个系统很慢。我想是COM2的RX_Buffer满了的原因。 所以再次请教同行,指点一二。

最近访客

< 1/1 >

统计信息

已有45人来访过

  • 芯积分:--
  • 好友:--
  • 主题:--
  • 回复:1

留言

你需要登录后才可以留言 登录 | 注册


现在还没有留言