基于LPC2210的RTL8019AS以太网驱动系统设计(三)

发布者:未来画家最新更新时间:2017-11-28 来源: eefocus关键字:LPC2210  RTL8019AS  以太网  驱动系统 手机看文章 扫描二维码
随时随地手机看文章

六.接收数据包模块

RTL8019AS接收数据有中断模式和查询模式两种。

Ø  采用中断模式时,需要在初始化程序中配置中断。当有一个正确的数据包到达时,RTL8019AS会产生一个中断信号,在中断处理程序中进行接收数据处理。

Ø  采用查询模式时,由主程序定时对接收缓冲区进行查询,当检测到有新的数据时,通过远程DMA方式将数据从RTL8019AS的RAM空间读出进行处理。

本驱动系统采用查询方式实现数据包的接收

6.1接收数据包模块的功能

在接收数据时,接收缓冲区构成一个循环FIFO队列。PSTART,PSTOP两个寄存器限定了循环队列的开始页和结束页,CURR为写入指针,受RTL8019芯片控制,BNRY为读出指针,有主机程序控制。根据CURR是否等于BNRY+1,来判断是否收到新的数据包,新收到的数据包存于CURR指定地址的RAM中。当CURR=BNRY时,RTL8019芯片停止接收数据包,反之,CURR按模增加。

6.2接收数据包模块的数据结构

Ø  REC_BUFF_UNION:定义共用体REC_BUFF_UNION   来存储接收到的以太网帧,因为一个最大以太网帧长度为1518bit,所以定义公用体容量为1536bit。

Ø  union  REC_BUFF_UNION     REC_BUFF[MAX_REC_BUFF];

REC_BUFF数组用来存储以太网帧,此系统定义最多可以接收5条最大以太网帧。

1>实现形式

       #define MAX_REC_BUFF        5

       union  REC_BUFF_UNION

              {

                     uint32  Dwords[384];

                     uint16  words[768];

                     uint8   bytes[1536];

              };

REC_BUFF_UNION      REC_BUFF[MAX_REC_BUFF];

2>定义uint16*REC_BUFF_PTR_WORDS,

             uint8    * REC_BUFF_PTR_BYTES,

用REC_BUF_PTR_WORDS来接收2字节数据,用REC_BUFF_PTR_BYTES来接收1字节数据。

3>以太以太网帧格式

 

6.3接收数据包模块的组成

第一 步:RTL8019AS以太网芯片从以太网读数据

该过程涉及的寄存器如下:

Ø  PSTART,PSTOP:以太网芯片接收数据缓冲区的起始,末页地址。形成一个接收缓冲区,每页256字节。

Ø  CURR:接收缓冲区写页指针

Ø  BNRY:接收缓冲区读指针

这四个寄存器在芯片初始化模块中被设置。

在初始化TPSR,BNRY,PSTART,PSTOP寄存器后,就定义了接收缓冲区和发送缓冲的容量和起始地址:

当有新数据包到来时,网络芯片会自动判断是否发送给本机;若是有新数据到来,则用本地DMA存入接收缓冲区,并自动修改写指针。


1>  接收数据包操作之前,先关中断

2>  判断是否发生溢出和复位。若发生,则初始化芯片,结束程序。

3>  获取读页指针bnry和写页指针curr。

4>  判断写页指针是否读取正确。若错误,则开中断,结束程序

5>  判断bnry+1是超过接收缓冲区末地址,若超过,则从接收缓冲区首地址开始读。

第二步:ARM LPC2210从网络芯片RTL8019AS中读数据

该过程涉及的寄存器同上,当对寄存器的具体赋值不同。

Ø  远程DMA起始地址的高字节位,赋为最后一次已经读取页的地址。低地址为0.

Ø  远程DMA的字节计数寄存器为待读的数据长度。

Ø  设置CR为0XA发送数据包

 

 


1>判断curr是否等于bnry+1,若不等于则有新的数据包到来,CURR按模增加。当CURR=BNRY时,RTL8019芯片停止接收数据包。

2>接收数据包之前,先判断接收缓冲环区是否达到最大(此系统,限定接收缓冲区最大为5)。若达到最大,则重第一个缓冲区开始存。

3>设定远程DMA起始地址和远程DMA数据字节计数器启动DMA读取以太网帧头部前4个字节存入程序数组。

4>清零远程DMA字节计数器并中止DMA读操作

5>根据接收到的以太网帧头判断接收帧是否错误,若有错误则进行错误处理,然后程序结束。

错误类型有:

Ø  接收状态是否错误

Ø  下一页指针是否正确

Ø  帧的长度是否大于1536

6>若数据包是完成的,读取剩下的数据

Ø  把bnry+4的地址赋值给远程DMA起始地址寄存器(RASR1,RSAR0)

Ø  把帧的长度赋值给远程DMA计算寄存器(RBCR0,RBCR1)

Ø  启动远程DMA读

7>从0x10远程DMA端口处,读取数据存放到缓冲区中

8>清零远程DMA字节计数器寄存器(RSCR1,RSCR0),并终止DMA操作。

9>读完一个帧后,修改读页bnry指针

10>修改完页指针后,判读读页指针是否到接收缓冲区首地址,若小于0X4C,则将binry恢复到接收缓冲区末地址处。

11>把修改过的读页指针写入BNRY处

12>清除所有中断标志    

13>判断以太网中的下一条协议字段值是否是ARP数据报或IP数据报,如果是则调用上层程序进行处理。如果不是则不处理。

Ø  判断是ARP或IP协议时,则REC_BUFF_NUM+1, 在下一个缓冲区接收新的以太网帧。

Ø  开中断

Ø  调用以太网报处理函数

Ø  循环判断是否有新的数据包到来

6.4接收数据包模块接口

接收包模块调用了写数据子模块,读数据子模块和页面切换子模块

 

Ø  读数据子模块: 从RTL8019AS中把数据读出。

Ø  写数据子模块:将数据写入RTL2019AS芯片中

Ø  页面切换子模块:可选择Page0,Page1,Page3三个页面

6.5接收数据包模块程序

/****************************Copyright(c)********************

**                                   西安邮电学院

**                                   graduate school

**                                                                 XNMS实验室

**                                  Author:冀博

**                                                                 Time:2011年2月21日

**                                 http://blog.csdn.net/tigerjb

**

**--------------FileInfo---------------------------------------------------------------------

****************************Copyright(c)******************** /

 

/**********************************************************

**函数原型:   unsigned char * Rec_Packet()

**入口参数:          无

**返 回 值:           程序正确返回0

**说    明:       查询是否有新数据包并接收进缓冲区

**********************************************************/

uint8 Rec_Packet()

{void Send_Packet(struct _pkst *TxdData)// 

{

       static uint8 REC_BUFF_NUM=0;

       //定义读页号bnry和写页号curr

       static uint8 bnry,curr;

       //存放以太网帧报头

       static uint16 tmp[2];

       uint16 * REC_BUFF_PTR_WORDS;

   uint8 * REC_BUFF_PTR_BYTES;

       uint8 i;

   uint16 ii,length;

   OS_ENTER_CRITICAL();

rea1:

       page(0);

       i=ReadFromNet(0X07);           

       //如果复位或益出就重新初试化

       if((i&0x90)!=0)

       {

              InitNic(0);

              OS_EXIT_CRITICAL();

              return(0);

       }

       bnry=ReadFromNet(0X03);

       page(1);

       curr=ReadFromNet(0X07);

       page(0);

       if(curr==0)

       {

              OS_EXIT_CRITICAL();

              return(0); 

       }

       bnry++;

       if(bnry>0x7f)

       {

              bnry=0x4c;

       }

   //判断是否有新的数据包到来

  if(bnry!=curr)

       if(REC_BUFF_NUM==MAX_REC_BUFF)

              {

                     REC_BUFF_NUM=0;

              }

REC_BUFF_PTR_WORDS=REC_BUFF[REC_BUFF_NUM].words;

       WriteToNet(0x09,bnry);   

       WriteToNet(0x08,0x00);

       WriteToNet(0x0b,0x00);  

       WriteToNet(0x0a,18);

       //启动远程DMA读操作

       WriteToNet(0x00,0x0a);

       for(i=0;i<2;i++)

              {

                     //每此读取2个字节

                     *REC_BUFF_PTR_WORDS=ReadFromNet(0x10);

                     tmp[i]=*REC_BUFF_PTR_WORDS;

                     REC_BUFF_PTR_WORDS++;

              }

       //清零远程DMA字节计数器并中止DMA读操作

       WriteToNet(0x0b,0x00);  

       WriteToNet(0x0a,0x00);

       WriteToNet(0x00,0x22);  

   //计算帧长度,将其长度放入缓冲区内

       tmp[1]=tmp[1]-4;

       REC_BUFF[REC_BUFF_NUM].words[1]=tmp[1];

   if(((tmp[0]&0x0001)==0)||((tmp[0]&0xff00)>0x7f00)

                     ||((tmp[0]&0xff00)<0x4c00)||(tmp[1]>0x0600))

       {

              page(1);

              curr=ReadFromNet(0X07);   

              page(0);

              bnry = curr -1;

              If(bnry < 0x4c)

                     {

                            bnry =0x7f;

                     }

       WriteToNet(0x03,bnry);

       WriteToNet(0x07,0xff);    

       OS_EXIT_CRITICAL();

        return(0);

   }

       else

       {

              WriteToNet(0x09,bnry);      

              WriteToNet(0x08,4);

              WriteToNet(0x0b,tmp[1]/256);        

              WriteToNet(0x0a,tmp[1]%256);

              WriteToNet(0x00,0x0a);

               length = tmp[1];

              for(ii=0;ii<((length+1)/2);ii++)

                            {

                                   *REC_BUFF_PTR_WORDS=ReadFromNet(0x10);

                                   REC_BUFF_PTR_WORDS++;

                            }

              //清零远程DMA字节计数器并中止DMA读操作

              WriteToNet(0x0b,0x00);  

              WriteToNet(0x0a,0x00);

              WriteToNet(0x00,0x22);  

   }

       bnry=(tmp[0]/256)-1;

       if(bnry<0x4c)

              {

                     bnry=0x7f;

              }

       WriteToNet(0x03,bnry);

       WriteToNet(0x07,0xff);    

       REC_BUFF_PTR_BYTES=REC_BUFF[REC_BUFF_NUM].bytes;

              REC_BUFF_PTR_BYTES=REC_BUFF_PTR_BYTES+4;

#ifdef Little_End

       if((((ipethernet*)REC_BUFF_PTR_BYTES)->NextProtocal==0x0008)             ||(((ipethernet*)REC_BUFF_PTR_BYTES)->NextProtocal==0x0608))

#endif

#ifdef Big_End

              if((((ipethernet*)REC_BUFF_PTR_BYTES)->NextProtocal==0x0800)

       ||(((ipethernet*)REC_BUFF_PTR_BYTES)->NextProtocal==0x0806))

#endif

              {

                     REC_BUFF_NUM++;

                     OS_EXIT_CRITICAL();

                     Rec_Ethernet_Packed(REC_BUFF_PTR_BYTES,0);

                     OS_ENTER_CRITICAL();

                     goto rea1;

              }

              else

                     goto rea1;//当没有数据时退出

       }

       OS_EXIT_CRITICAL();

       return(0);

}


关键字:LPC2210  RTL8019AS  以太网  驱动系统 引用地址:基于LPC2210的RTL8019AS以太网驱动系统设计(三)

上一篇:基于LPC2210的RTL8019AS以太网驱动系统设计(四)
下一篇:基于LPC2210的RTL8019AS以太网驱动系统设计(二)

推荐阅读最新更新时间:2024-03-16 15:47

Optiphase推出五相电机驱动系统 可提高车辆安全性/降低成本
据外媒报道,美国得克萨斯州电机与控制器专家Optiphase Drive Systems发布了一款独特的五相电机驱动系统,以取代传统的三相电机系统,从而简化实现脱碳。
[汽车电子]
Optiphase推出五相电机<font color='red'>驱动</font><font color='red'>系统</font> 可提高车辆安全性/降低成本
适用于高亮度LED照明系统的LED驱动器LM3450
  适用于高亮度LED照明系统的LM3450 LED 驱动器内置主动式功率因素修正器(PFC)和相位调光译码器,确保可在极宽的可编程调光范围内灯光的明暗变化稳定,不会出现闪烁情况。   采用相位调光器的住宅和商用照明系统必须配备可将相位斩波波形正确解码的电路,以便调光器能稳定调控LED的亮度。目前市场上的可调光LED驱动器很多时候都不符合正相调光器或TRIAC调光器有关最低电流的规定,导致调光器调控亮度时突然关闭或“错误启动(misfire)”,使得灯光因为无法准确解译相位角而出现闪烁,而且在调光率极低时闪烁尤其明显。为了解决这一问题,目前的驱动器都会缩小LED的调光范围或不断耗散电能,以确保调光器不会错误启动。   这款设计
[电源管理]
适用于高亮度LED照明<font color='red'>系统</font>的LED<font color='red'>驱动</font>器LM3450
工业以太网安全性初探
1简介工业以太网及存在的安全问题     企业信息化网络可分为三个层次。从下到上依次为现场设备层、过程监控层和信息管理层。最上层的是企业信息管理网络,它主要用于企业的生产调度,财务、人事以及企业的经营管理等方面信息的传输;中间的过程网络主要用于将的现场信息置入实时数据库,实现现场数据的存储、管理、查询的等基本的功能;底层的现场设备层网络则主要用于控制系统中大量现场设备之间测量一与控制信息的传输。其中底层现场设备对通信响应的实时性和确定性要求较高,因此目前现场设备网络主要由现场总线低速网段组成。     传统工业控制网络由于其技术陈旧及其三协议不统一,导致不便于通讯的特点,在许多场合已经不能满足现实的需要。同时由于以太网技术
[嵌入式]
利用恒流LED驱动器设计高效率LED照明系统
随着高功率LED的问世,照明产业也面临新的挑战。LED的使用寿命及电源转换效率成为设计LED照明系统时的主要考虑因素。而为了提供恒流以维持LED色彩与亮度的一致性,恒流LED驱动器可作为一个提供恒流输出的开关式转换器。此外,省电或高效率的电源转换需求更是在LED照明应用上不可缺少的要素,而磁滞型脉冲频率调变技术(Hysteretic PFM)可以大幅提升轻载或重载时的电源转换效率。本文将探讨如何利用恒流LED驱动器设计出高效率、高稳定性的LED照明系统。 传统LED驱动器:定电压模式 流经LED的电流决定了LED的亮度,电流越大,LED的亮度也会越亮。一般而言,使用定电压或恒流驱动器都可达到点亮LED的目的。图1为最简单的定电压L
[嵌入式]
40G以太网产品加快商用步伐
     如今10G以太网产品已经开始普及,其市场份额约占总额为180亿美元以太网交换机市场的25%,以后还将会继续增长。许多人关注的是,10G以太网的后续产品是什么?      虽然10G以太网产品还没有成熟,但是下一波以太网交换机浪潮即将开始。下一代以太网可能是40G/100G以太网,也可能是兆兆位以太网,甚至有可能是两者之间的某一种标准。实际上,40/100G以太网标准已经在近日获得批准,该标准的产品也将上市销售。美国极进网络公司、 Force10网络公司和BLADE网络技术公司均已经宣布其交换机支持40G以太网端口的数据中心和应用。思科、Juniper、博科和阿朗也都宣布或开始在他们的服务提供商路由器中出货100G以太
[网络通信]
基于NioslI的SOPC系统中lED显示驱动IP核设计
  NioslI 嵌入式 处理器是A1tera公司提出的S OPC 解决方案,是一种用户可随意配置和构建的32位嵌入式处理器,结合丰富的 外设 可快速、灵活地构建功能强大的SOPC系统。A lte ra公司提供了一些通用的IP核,使得用户可轻松集成属于自己的专用功能;但对于一些特定的外设,没有现成可用的IP核,如 液晶 模块CBGl28064等。   用户可通过自定义逻辑的方法在SOPC设计中添加自定义IP核。在实际应用中, LCD 液晶 显示 器凭借功耗低、体积小、轻薄及控制 驱动 简单等特点,在智能仪器、仪表和低功耗电子产品中得到了广泛应用。本文以深圳秋田视佳实业有限公司的液晶显示模块CBGl28064为例,在基于Ni
[电源管理]
基于NioslI的SOPC<font color='red'>系统</font>中lED显示<font color='red'>驱动</font>IP核设计
驱动系统发展及关键技术
扁线电机2021年渗透率约为27%,预计今年渗透率可达40%,随着扁线技术的成熟,未来用量增长迅猛。
[嵌入式]
电<font color='red'>驱动</font><font color='red'>系统</font>发展及关键技术
纳芯微推出NSI22C1x系列隔离式比较器,助力打造更可靠的工业电机驱动系统
纳芯微今日宣布推出基于电容隔离技术的隔离式比较器NSI22C1x系列, 该系列包括用于过压和过温保护的隔离式单端比较器NSI22C11和用于过流保护的隔离式窗口比较器NSI22C12。 NSI22C1x系列可用于工业电机驱动、光伏逆变器、不间断电源、车载充电机的过压、过温和过流保护,在提升系统可靠性的前提下,支持更高功率密度的系统设计,同时简化外围电路,相比传统分立方案,可将系统保护电路尺寸缩小60%。 以工业电机驱动系统为例,其正朝着更高效率、更高功率密度和更高可靠性的方向发展,同时伴随着以 SiC和GaN 为代表的宽禁带半导体在功率器件上的应用,对系统的可靠性,尤其是过流及短路保护的响应时间提出了更高的要求。纳芯
[工业控制]
纳芯微推出NSI22C1x系列隔离式比较器,助力打造更可靠的工业电机<font color='red'>驱动</font><font color='red'>系统</font>
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved