ETH_Rx_Packet疑惑/F4探索者

2019-07-20 07:04发布

FrameTypeDef ETH_Rx_Packet(void)
{
        u32 framelength=0;
        FrameTypeDef frame={0,0};   
        //检查当前描述符,是否属于ETHERNET DMA(设置的时候)/CPU(复位的时候)
        if((DMARxDescToGet->Status&ETH_DMARxDesc_OWN)!=(u32)RESET)
        {       
                frame.length=ETH_ERROR;
                if ((ETH->DMASR&ETH_DMASR_RBUS)!=(u32)RESET)  
                {
                        ETH->DMASR = ETH_DMASR_RBUS;//清除ETH DMA的RBUS位
                        ETH->DMARPDR=0;//恢复DMA接收
                }
                return frame;//错误,OWN位被设置了
        }  
        if(((DMARxDescToGet->Status&ETH_DMARxDesc_ES)==(u32)RESET)&&
        ((DMARxDescToGet->Status & ETH_DMARxDesc_LS)!=(u32)RESET)&&  
        ((DMARxDescToGet->Status & ETH_DMARxDesc_FS)!=(u32)RESET))  
        {  //              ((DMARxDesc->Status&ETH_DMARxDesc_FL)>>ETH_DMARXDESC_FRAME_LENGTHSHIFT)   
                framelength=((DMARxDescToGet->Status&ETH_DMARxDesc_FL)>>ETH_DMARxDesc_FrameLengthShift)-4;//得到接收包帧长度(不包含4字节CRC)
                frame.buffer = DMARxDescToGet->Buffer1Addr;//得到包数据所在的位置
        }else framelength=ETH_ERROR;//错误  
        frame.length=framelength;
        frame.descriptor=DMARxDescToGet;  
        //更新ETH DMA全局Rx描述符为下一个Rx描述符
        //为下一次buffer读取设置下一个DMA Rx描述符
        DMARxDescToGet=(ETH_DMADESCTypeDef*)(DMARxDescToGet->Buffer2NextDescAddr);   
        return frame;  
}

我的问题是:从红 {MOD}标出的代码可以看出frame.buffer 中存放的是接收描述符链表中最后一个描述符对应的接收缓冲区地址。比如用了5个描述符接收一帧数据,那么frame.buffer 中存放的是第5个描述符对应的接收缓冲区地址?不知道这样理解对不对?  
我自以为应该是第一个描述符对应的缓冲区地址是接收数据包的地址,但是从代码看接收数据包的地址应该是描述符链表的最后一个描述符对应的缓冲区地址,请释疑。

友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。