综合资讯 在线阅读 原文阅读 在线商城 下载专区 DATASHEET 技术论坛 商务频道

嵌入式系统  单片机  D S P  EDA/PLD  接口电路  存储技术  显示光电  电源技术
传感/控制  模拟技术  通信网络  无线通信  电测仪表  消费电子  汽车电子

所在的位置:首页技术文章单片机正文
 
用8位单片机实现串口-以太网转换器
发布日期:2005-12-14 作者:蔡宁果 何晓琼 来源:电子技术应用

  摘要:用8位单片机8031和ISA总线网卡,实现RS485串行设备与以太网的连接,以传送控制信令和数据文件。程序设计采用C51语言,便于移植和调试。

    关键词:以太网 串行通讯 单片机 C51

单片机或微控制器(MCU)(也称为嵌入式系统)已经在各个领域得到了广泛的应用。目前绝大多数系统都是以MCU为核心,与监测、伺服、指示设备配合实现一定的功能。以太网是当今最受欢迎的局域网之一,现已成为社会重要的基础信息设施,是信息流通的重要渠道。如果嵌入式系统能够连接到Internet,则可以方便、低廉地将信息传送到世界上的任何一个地方。

将嵌入式系统与Internet相连的主要困难在于:Internet的各种通信协议对存储器、运算速度等的要求比较高;而嵌入式系统中除部分32位处理器外,大量存在的8位和16位MCU,支持TCP/IP等Internet协议将占用大量系统资源,影响本来的功能或根本不可能实现。

本文用8031单片机和RTL8019AS网卡实现了RS485串口设备数据文件通过以太网传输到远端计算机的功能。

1 串行通讯

串行通讯在通讯领域被广泛应用。RS232接口已成计算机、计算机外设、交换机和许多通讯设备的标准接口。在我国工业总线的应用中,RS485、RS422使用最为普遍。

在串行接口连接中,按连接方式可分为:面向连接和无连接。无连接原理比较简单,通讯双方无握手过程。一方如有数据需要发送,则立即通过串行接口发送出去,另一方被动接收。该方式能够达到较高的通讯速率,但不能保证数据传输的可靠性,可用于对数据可靠性要求不高的场合,如语音、图像等。而面向连接方式则不同。甲方有数据发送请求时,向乙方发送“请求发送数据”命令;乙方收到后,如准备就绪,则回送确认信息;甲方得到乙方的确认后方可发送数据。大多数情况下,乙方要对收到的数据进行校验,校验正确发送“通讯终止”命令;否则发送“重发”命令。面向连接的串行通讯过程实现起来要复杂得多,通常用于数据文件的传输。

2 以太网的物理传输帧

标准IEEE802.3帧结构由七部分组成,如表1所示。除了数据域的长度不固定外,其他部分的长度都是固定不变的。在发送数据时,帧头、起始位和校验位都是网卡自动添加;在接收数据时,帧头和起始位将被网卡自动跳过,即网步一旦检测到有效帧头和帧超始位,就认为有有效数据开始,并将有效数据存入接收缓冲环。

表1 标准IEEE802.3帧结构

帧头 起始位 目的地址 源地址 数据长度 数据域 校验位
62位 2位 48位 48位 16位 不超过1500字节 32位

3 以太网卡

RTL8019AS 网卡是8/16位ISA总线的网卡,遵循IEEE802.3协议。按功能可将其划分为:接收功能模块、CRC产生模块、发送功能模块、地址识别模块、 FIFO控制模块、协议逻辑阵列模块及DMA和缓冲控制模块。对网卡进行编程可以实现局址网内任意站点之间的通信而需要网络操作系统的支持。

熟悉网卡接口电路是对网理编程的首要条件。网卡接口电路可分为两部分:一是与计算机ISA总线相连,包括数据总线读写、地址总线驱动、中断控制信号的产生、存储器读写信号以及I/O端口读写信号的引入等;二是对网卡内部的操作,包括对缓冲RAM的读写、对RTL8019AS的控制、读站地址PROM以及读自举ROM等。ISA总线共有98个信号,通过对网卡工作原理的分析,可以将接口信号线减至最少。2表是驱动RTL8019AS网卡所需的信号线。

表2 系统所使用的网卡ISA总线信号线

信号线 引  脚
数据信号线
地址信号线
地址允许线
I/O通道准备好信号线
复位信号线
I/O读信号
I/O写信号
I/O片选16位信号
SD0~SD15
SA0~SA19
AEN
IOCHRDY
RESETDRV
IOR
IOW
IOCS 16

4 硬件框图

系统采用8031为CPU主芯片,使用32K字节的外部存储器62256来存放以太网包(最大可以有1500字节)和串行数据,8K字节的2764存放程序,用75176与485总线通讯。系统的数据和地址总线分别与网卡的数据和地址总线相连。硬件框图如图1所示。

5 软件设计

对网卡编程就是对网络接口控制器(NIC)RTL8019AS中各种寄存器进行编程控制,从而完成数据分组的正确发送和接收。所有程序采用Franclin C51语言编制,具有可读性强、移植性好、开发周期短的特点。在代码的使用效率上,也完全可和汇编语言相比。

5.1 主程序

主程序可分为网络通讯和串行通讯两部分。网络通讯过程又可分为网卡初始化、发送控制和接收控制三部分。主程序框图如图2所示。

5.2 网卡初始化过程

对网卡的初始化就是对相关寄存器进行初始化。这些寄存器包括CR、DCR、RBCR、PSTART、PSTOP、ISR、IMR、PAR0~PAR5、MAR0~MAR5、CURR、TCR和RCR等。初始化过程如下:

(1)CR=0x21:选择页0寄存器,将NIC处于离线状态;

(2)DCR=0x88:8位内存访问,正常工作方式;

(3)RBCR0=0,RBCR1=0:远程DMA操作时传递字节数清零;

(4)RCR=0xc0:接收到的帧存入缓冲环;

(5)TCR=0xe2:环路测试状态;

(6)PSTART=0x4c,PSTOP=0x80:构造缓冲环;

(7)ISR=0xff:中断寄存器清零;

(8)IMR=0x00:屏蔽所有的中断;

(9)CR=0x61:选择页1;

(10)设置网卡地址PAR0~PAR5;

(11)设置多址寄存器MAR0~MAR5;

(12)CURR=0x4d:初始化当前页寄存器;

(13)CR=0x22:选择页1,正常工作状态;

(14)TCR=0XE0:发送器正常工作状态。

5.3 发送控制过程

在网络中,帧传输的过程就是发送方将待发送的数据按帧格式要求封装成帧,然后通过网卡发送到网络的传输线上。发送程序框图如图3所示。

5.4 接收控制过程

帧的接收过程分为两步:第一步由本地DMA将帧存入接收缓冲环中;第二步由远程DMA将接收缓冲环中的帧读入内存。即将网络上的数据帧接收并缓存在网卡的接收缓冲环中,然后由主机程序将缓存在缓冲环中的帧读走并存入内存中。

帧的接收工作由网卡自动完成,只需对相关的寄存器和PSTART、PSTOP、CURR和BNRY进行适当的初始化即可。

帧读入较帧接收要复杂一些。首先必须初始化相应的寄存器RSAR、RBCR,然后再启动远程DMA读操作和主机程序的读端口操作。

以下是接收数据帧的子程序。为了获得数据长度,先读入18个字节的数据,然后根据有交数据的长度将帧完整读入。为了启动远程DMA读操作,应该令CR= 0AH,远程DMA将从接收缓冲环的DMA地址处读入1字节并送往I/O数据端口,由主机程序读入内存。这一过程将一直持续到RBCR寄存器为0。

Void Receive_Data()

{

unsigned char data value,temp;

unsigned int data datalength,i;

RSARI=Next_PKT;

RSAR0=0;

RSAR0=18;

RBCR1=0;

CR=0x0a;

for(i=0;i<18;i++){

value=Data_Port;

recv_buf[i]=value;

}

datalength=(recv_buf)[16]<<8)+recv_buf[17]+18;

value=datalength&0x00ff;

RBCR0=value;

value=(datalength&0xff00)>>8;

RBCR1=value;

RSAR1=Next_PKT;

RSAR0=0;

CR=0x0a;

For(I=0;I<datalength;i++){

Value=Data_Port;

Recv_buf[i]=value;

}

}

    5.5 串口通讯子程序

为实现数据文件的串口传输编制了一个串口通讯协议。该协议由引导帧、长度帧、数据帧和确认帧等组成。其中引导帧用于同步每一包数据的引导头,长度帧是这一包数据的总长度,数据帧是其中的数据信息,确认帧是接收方对发送方的回应。每帧数据由16个字节组成,每帧的第14个字节为标志位,第15字节为校验位。标志位中有2位帧标志位,3位序号位。校验采用和校验,只计算0~13字节,溢出值舍去。在发送方有数据发送时,先检测线路是否空闲,如线路空闲则向收方发送“请求发送数据”命令帧。接收机收到后,如准备就绪,则回送“可以发送”的确认命令。发送方得到确认后开始发送数据。接收方对收到的每一帧数据进行和校验,校验正确发送“和校验正确”命令,发送方发送下一帧;否则发送“重发”命令,发送方重发此帧。协议中还具有等待超时处理、帧不同步处理和线路冲突检测功能。

利用8位单片机8031驱动ISA总线网卡,实现串口设备通过以太网进行通讯,可以方便、可靠、低廉地将数据传输到远端设备。而且,通过串口设备与以太网的相连,可以很好地解决多种工业总线的系统集成问题,同时也大大丰富了工业总线的体系,促使其向更高层次发展。可以预计,小型串口设备与以太网相连将带来一场新的技术浪潮


 (全文结束)

信息发布:   转引自: 【 】 【打印】 【关闭
 相 关 文 章
AD7730在发动机燃油消耗测量仪中的应用 (12-17)
TMS320VC5410的McBSP串行接口技术与程序设计 (12-16)
一个单片机串行数据采集/传输模块的设计 (12-15)
基于单片机的接口转换设计及应用 (12-19)
改进型高速8位ADC TLC0820及其在测光电路中的应用 (12-21)
高速数模转换器TQ6124的原理与应用 (12-31)
单片机内部模拟比较器的应用 (12-27)
并行D/A转换器AD7237A及其接口设计 (12-21)
16位A/D转换器CS5521在双色红外信号检测中的应用 (12-11)
八路13位数模转换器MAX547的原理及应用 (12-11)
高速A/D转换器TLC5540及其应用 (12-11)
24位高精度A/D芯片ADS1211的应用 (12-11)
24位模数转换器AD7713及其应用 (12-11)
一种12位双通道高速数据采集处理系统 (12-11)
DS2450 A/D转换器的特性与应用 (12-11)
具有16通道的8位DAC芯片 (12-11)
24位A/D转换器ADS1210/1211及其应用 (12-11)
高精度A/D转换器AD7711A及应用 (12-11)
一种新型便携式静态应变仪的研制 (02-08)
网络化智能传感器中以太网接口设计 (11-10)
一种采集系统高速以太网数据转发器的实现 (12-26)
交换式路由器的千兆比以太网接口设计和实现 (12-25)
嵌入式系统以太网接口的设计 (12-24)
POWERPC 860T实现多以太网口通信 (12-27)
基于PC104总线的嵌入式以太网卡设计 (12-27)
基于工业以太网现场控制器的开发 (02-10)
FCS技术国内应用的现状及存在的问题 (01-06)
校园网络系统的设计与实施 (01-01)
基于“网络通”的以太网家庭数据终端 (12-24)
以太网桥接专用集成电路的实现 (12-19)
远程数据传输的研究 (11-24)
基于FPGA的十端口千兆以太网接口的设计与实现 (11-15)
核心路由器千兆以太网线卡输入数据的分路设计与实现 (11-14)
一种HomePNA调制解调器的设计与实现 (12-08)
基于SOPC的嵌入式工业以太网控制器设计 (12-12)
用于单片机的以太网网关--网络通 (12-18)
基于FPGA的以太网MII接口扩展设计与实现 (12-12)
10G以太网的UTOPIA接口设计与实现 (03-31)
关于我们 ┋ 友情链接


深圳市福田区海滨广场恒福花园恒华阁11F
电话:0755-88305872 传真:0755-88305880
Copyright©2005-2007 无忧电子开发网版权所有

粤ICP备05064233号