周立功的tcp/ip代码里的hardware.c里rec_packet函数里有这么一段
if(bnry!=curr) //此时表示有新的数据包在缓冲区里
{ //在任何操作都最好返回page0
if(REC_BUFF_NUM==MAX_REC_BUFF)//接收缓冲区号清零
{
REC_BUFF_NUM=0;
}
REC_BUFF_PTR_WORDS=REC_BUFF[REC_BUFF_NUM].words;//设定接收缓冲区的起始地址
//=======================================
WriteToNet(0x09,bnry); //RSAR1写入读页地址的高字节
WriteToNet(0x08,0x00); //RSAR0写入读页地址的低字节
WriteToNet(0x0b,0x00); //RSCR1写入读取字节计数高字节
WriteToNet(0x0a,18); //RSCR0写入读取字节计数高字节
WriteToNet(0x00,0x0a); //启动Remote DMA读操作
//读取一包的前4个字节:4字节的8019头部
for(i=0;i<2;i++)
{
*REC_BUFF_PTR_WORDS=ReadFromNet(0x10);
tmp=*REC_BUFF_PTR_WORDS;
REC_BUFF_PTR_WORDS++;
}
//0:接收状态;1:下一包的指针;2:本包低位;3:本包高位;
//=======================================中止DMA操作
WriteToNet(0x0b,0x00); //RSCR1写入读取字节计数高字节
WriteToNet(0x0a,0x00); //RSCR0写入读取字节计数高字节
WriteToNet(0x00,0x22); //结束或放弃DMA操作
//=======================================
tmp[1]=tmp[1]-4;//去掉4个字节的CRC
REC_BUFF[REC_BUFF_NUM].words[1]=tmp[1]; //把真正的接收的帧的长度保存到缓冲区
//=====================以上各步操作表示读入的数据包有效
//0:接收状态;1:下一包的指针;2:本包高位;3:本包低位;
if(((tmp[0]&0x0001)==0)||((tmp[0]&0xff00)>0x7f00)
||((tmp[0]&0xff00)<0x4c00)||(tmp[1]>0x0600))
{//接收状态错误或下一数据包的起始页地址错误或接收的数据包长度>1536字节
page(1);
curr=ReadFromNet(0X07); //page1读取CURR的值
page(0); //切换回page0
bnry = curr -1; //把bnry恢复为下16K中的空余部分
if(bnry < 0x4c)
{
bnry =0x7f;
}
WriteToNet(0x03,bnry); //把BNRY恢复到指向下一帧write to bnry
WriteToNet(0x07,0xff); //清除中断标志
//goto rea1;
OS_EXIT_CRITICAL();
return(0);
请问,那个tmp接受到的是什么数据?是以太帧的前两个字节吗?tmp[1]=tmp[1]-4;为什么是去掉4个字节的CRC?难道tmp[0]和tmp[1]包括了整个数据帧的全部?
|