学士学位论文-基于-MCU-的以太网接入模块设计.doc
《学士学位论文-基于-MCU-的以太网接入模块设计.doc》由会员分享,可在线阅读,更多相关《学士学位论文-基于-MCU-的以太网接入模块设计.doc(17页珍藏版)》请在咨信网上搜索。
1、 学 士 学 位 论 文基于MCU的以太网接入模块设计姓 名:学 号:指导教师:院系(部所):专 业:完成日期:2013年05月15日摘 要 给出了单片机控制RTL8019AS实现以太网通讯的软硬件设计方案。首先设计了系统的硬件电路,并对接口电路的设计进行了详细的阐述,然后设计了RTL8019AS的以太网驱动程序最后通过一个简单的数据收发试验验证了设计的正确性。关键词 RTL8019AS; 51单片机; TCP/IP协议;传感器AbstractGiven SCM RTL8019AS Ethernet communications hardware and software design. De
2、sign the hardware circuit, the interface circuit design in detail, and then design RTL8019AS Ethernet driver. Send and receive data through a simple test to verify the correctness of the design.Key words The RTL8019AS; 51 microcontroller; TCP / IP protocol; sensor目 录第1章 绪论71.1本设计的背景71.2以太网络接口芯片RTL80
3、19AS 介绍7第2章、系统总体结构设计102.1系统控制模块的硬件设计102.11控制系统的主要硬件电路102.2系统控制模块的软件设计102.21 TCP/ IP 协议102.22 软件设计流程112.3程序部分112.31主程序112.32发送控制过程132.33接收控制过程14第3章 总结16第4章 参考文献17第5章 设计总结18第6章 致谢19第1章 绪论1.1本设计的背景随着互联网技术的飞速发展,Internet网络日益成为人们日常生活中必不可少的工具。人们在使用互联网学习、娱乐的同时,各种家电设备、仪器仪表以及工业生产中的数据采集与控制设备在逐步地走向网络化,以便共享网络中庞大
4、的信息资源,给人们的工作学习带来更大的便利。就目前来看,利用 8位的微处理器,实现与Internet网络的通信,具有十分重要的意义。本设计主要为了解决利用单片机控制网卡芯片实现以太网的链接,已达到最大程度的利用网络资源,方便人们生活学习的目的。1.2以太网络接口芯片RTL8019AS 介绍RTL8019AS: 是台湾Realtek 公司制造的一种高集成度的10 Mb/ s 以太网控制芯片, 可实现基于以太网协议的MAC 层的全部功能,内置16 kB SRAM、双DMA 通道和FIFO,可完成数据包的接收和发送功能。主要性能( 1) 符号Ethernet 与IEEE802.3 ( 10Base5
5、,10Base2, 10BaseT) 标准;( 2) 全双工, 收发可同时达到10 Mb/ s 的速率;( 3) 内置16 kB 的SRAM, 用于收发缓冲, 降低对主处理器的速度要求;( 4) 支持8/ 16 位数据总线8 个中断申请线以及16 个I/ O 基地址选择;( 5) 支持UTP,AUI,BNC自动检测还支持对10BaseT 拓扑结构的自动修复;( 6) 允许4个诊断LED 引脚可编程输出;( 7) 100 脚的PQFP 封装,缩小了PCB 尺寸。内部结构:RTL80l9AS内部可分为远程DMA接口、本地DMA接口、MAC(介质访问控制)逻辑、数据编码解码逻辑和其他端口。内部结构如
6、图l所示ISA总线接口ENA(编码译码)逻辑即插即用PnPBoot ROM端口EEPROM端口AUI接口双绞线接口8K*16SROMMAC逻辑图一 远程DMA接口是指单片机对RTL80l9AS内部RAM进行读写的总线,即ISA总线的接口部分。单片机收发数据只需对远程DMA操作。本地DMA接口是指RTL80l9AS与网线的连接通道,完成控制器与网线的数据交换。MAC(介质访问控制)逻辑完成以下功能:当单片机向网上发送数据时,先将一帧数据通过远程DMA通道送到RTL80l9AS中的发送缓存区,然后发出传送命令;当RTL80l9AS完成了上一帧的发送后,再开始此帧的发送。RTL80l9AS接收到的数
7、据通过MAC比较、CRC校验后,由FIFO存到接收缓冲区;收满一帧后,以中断或寄存器标志的方式通知主处理器。FIFO逻辑对收发数据作l6字节的缓冲,以减少对本地DMA请求的频率。2.3内部RAM地址空间分配RTL8Ol9AS内部有两块RAM区。一块l6K字节,地址为OX4OOOOX7fff;一块32字节,地址为OXOOOOOXOOlf。RAM按页存储,每256字节为一页。一般将RAM的前l2页(即OX4OOOOX4bff)存储区用作发送缓冲区;后52页(即OX4cOOOX7fff)存储区用作接收缓冲区。第O页叫Prom页,有32字节,地址为OXOOOOOXOOlf,存放以太网物理地址。要接收和
8、发送数据包就须通过DMA读写RTL8Ol9AS内部的l6KBRAM。实际上它是双端口的RAM,是指它有两套总线连接到此RAM,一套总线是RTL8Ol9AS读或写此RAM,即本地DMA;另一套总线是单片机读或写该RAM,即远程DMA第2章、系统总体结构设计2.1系统控制模块的硬件设计系统控制单元以单片机主控模块为核心其他外围电路主要包括:ISP下载线模块、系统供电模块、硬件时钟模块、网络接口卡模块、外部数据采集模块。2.11控制系统的主要硬件电路本系统的主控模块主要采用STC公司的89C52作为主控芯片 其中具体包括在线编程模块电路、系统复位电路、系统供电电路、网卡驱动电路、外部数据采集电路。要
9、实现8位微处理器的上网首先要解决的就是与以太网的连接问题,即如何将通用处理器的网络装置应用于嵌入式网络的开发与应用。目前市面上有许多型号的以太网控制芯片,多数功耗较高、功能复杂,不适合用于价格低廉的嵌入式系统。还需要考虑的一点是网络接口芯片(RTL8019AS)与单片机的接口不能太复杂,要尽量少占用单片机的系统资源。根据上面的原则,选用RTL 8019AS作为网络接口芯片,网络接口卡设计方案如图二所示。单片机外部RAM存 存储器网络控制器隔离滤波器RJ45串口电平转换芯片Pc机网络接口串口EEPROM 图二2.2系统控制模块的软件设计2.21 TCP/ IP 协议嵌入式设备网络化的关键是实现T
10、CP/ IP 网络协议。众所周知, TCP/ IP 是一个数量庞大的协议体系,是由几百种网络协议组成的集合, 在嵌入式系统有限的资源中难以完全实现。且嵌入式系统以应用为中心, 即使具有特定功能的计算机系统, 也不需要实现那么多的协议。因此系统设计的首先就是进行TCP/ IP 协议栈子集的选择。TCP/ IP常被认为是一个由链路层、网络层、传输层和应用层组成的四层协议系统, 且每一层都有相应的协议集合用以实现不同的功能。数据链路层主要处理和传输介质相关的物理接口部分, 考虑到以太网数据流量大并且通用性强, 因此采用以太网协议, 用RJ45接口把嵌入式设备连入网络。网络层主要作用是处理数据包在网络
11、中的协议封装,该层选用TCP/ IP 协议栈的核心IP 协议, 同时选用ARP 协议实现IP 地址到MAC 物理地址的转换。传输层主要为两台主机上的应用程序提供端到端的通信,有UDP和TCP两种协议。UDP协议是不面向连接的, 因此不能保证数据传输的可靠性。TCP是面向连接的,但是其可靠性的保证是以许多复杂措施以及由此而增加的开销为代价换来的。因此在此选择TCP为传输层协议,但是针对应用进行简化以适应嵌入式应用的要求。应用层负责处理特定的应用程序部分, 应用层协议种类很多, 考虑到嵌入式应用的特殊性,不选取通用的应用层协议。2.22 软件设计流程对网卡编程就是对网络接口控制器(NIC)RTL8
12、019AS 中各寄存器进行编写程序控制,进而完成数据分组的正确发送及接收。2.3程序部分2.31主程序主程序可分为网络通讯和串行通讯这两部分。网络通讯又可分为网卡初始化、发送控制和接收控制三部分。主程序框图如图三 所示。Y初始化串口初始化网卡接收串口数据装入以太网帧接收以太网帧收到确认帧N图三网卡初始化过程如下:RTL8019AS的初始化主要是设置一些工作参数,如RAM的分配,中断初始化,MAC地址设置,接收设置,发送设置等,具体在以下程序中注释。void rtl8019Init(void)RTL8019_RESET_PORT_H(); delayms(50); RTL8019_RESET_P
13、ORT_L(); /RTL8019AS复位管脚置0RTL8019WRITE( ISR, rtl8019Read(ISR) ) ; / 软件复位delayms(50); RTL8019WRITE(CR, 0xE1); / 选择第3页,配置寄存器 RTL8019WRITE(0x01, 0xC0); /EEM1=EEM0=1 RTL8019WRITE(CONFIG2, 0x20);/设置网卡为10M自动检测模式 RTL8019WRITE(CONFIG3, 0); /设置LED工作模式 delayms(255); RTL8019WRITE(0x01, 0); /EEM1=EEM0=0 RTL8019W
14、RITE(CR, 0x21); /第0页delayms(2);RTL8019WRITE(DCR, DCR_INIT); / #define DCR_INIT 0x58RTL8019WRITE(RBCR0,0x00);RTL8019WRITE(RBCR1,0x00);RTL8019WRITE(RCR,0x04); /接收结构寄存器RTL8019WRITE(TCR,0x02); /传送配置寄存器RTL8019WRITE(TPSR, TXSTART_INIT); /#define TXSTART_INIT 0x40RTL8019WRITE(PSTART, RXSTART_INIT); /#defin
15、e RXSTART_INIT 0x47RTL8019WRITE(BNRY, RXSTART_INIT); /#define RXSTART_INIT 0x47RTL8019WRITE(PSTOP, RXSTOP_INIT); /#define RXSTOP_INIT 0x60RTL8019WRITE(ISR,0xFF); /清除中断标志RTL8019WRITE(IMR, IMR_INIT); /中断屏蔽RTL8019WRITE(CR, 0x61); /第1页delayms(2);RTL8019WRITE(CURR, RXSTART_INIT); /#define RXSTART_INIT 0x
16、47 /设置MAC地址RTL8019WRITE(PAR0+0, MYMAC_0);RTL8019WRITE(PAR0+1, MYMAC_1);RTL8019WRITE(PAR0+2, MYMAC_2);RTL8019WRITE(PAR0+3, MYMAC_3);RTL8019WRITE(PAR0+4, MYMAC_4);RTL8019WRITE(PAR0+5, MYMAC_5); RTL8019WRITE(CR, 0x22);/ start the NIC /end rtl8019as init2.32发送控制过程在网络中,帧传输的过程就是发送方将待发送的数据按帧格式要求封装成帧,然后通过网卡
17、发送到网络的传输线上。发送程序框图如图4所示。数据长度=46数据长度+14初始化远程字节计算器RBCR启动远程DMA数据写入缓冲区启动本地DMA发送字节计数器赋值初始化发送页起始地址寄存器TTTPSR发送缓冲区数据到网上初始化数据长度小于46度,444444646发送完毕发送完毕返回YYNNNYYY图四首先设置网卡发送数据包的RAM首地址,用以存放要发送的数据,和上两节写RAM相同。然后设置远程读此数据包的长度,(RBCR1,0在读数据包的时候作用为要读数据包的长度;在发送数据包的时候作用为远程接收此包时,此包的有效字节长度,相当于RTL8019AS接收数据包的Byte3,4,详细请看第二章的
18、3.9节),然后设置发送数据包的长度,:发送数据包的长度与远程读此数据包的长度是一样的吧!然后把要发送的数据包写入RAM,启动发送数据包命令,发送数据包,程序如下:RTL8019WRITE(CR,0x22); /第0页 开始命令while( rtl8019Read(CR) & 0x04 ); /有数据包发送则等发送完毕RTL8019WRITE(TPSR,0x40); /加载发送RAM页的首地址RTL8019WRITE(RSAR0,0x00); /写RAM地址 低8位RTL8019WRITE(RSAR1,0x40); /写RAM地址 高8位RTL8019WRITE(ISR,(18); /远程读数
19、据包长度的高8位RTL8019WRITE(TBCR0, (unsigned char)(sendPacketLength); /发送数据包长度的低8位RTL8019WRITE(TBCR1, (unsigned char)(sendPacketLength)8);/发送数据包长度的高8位 RTL8019WRITE(CR,0x12); /启动写RAM命令for(unsigned int i=0;ilength;i+) RTL8019WRITE(RDMAPORT, Bufferi); /写数据到RAMRTL8019WRITE(CR,0x24); /发送数据包 CR的TXP=1RTL8019WRITE
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 学士学位 论文 基于 MCU 以太网 接入 模块 设计
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【可****】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【可****】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。