当前位置:首页 > 单片机 > 单片机
[导读]随着互联网的迅速发展,网络用户飞速增长,在使用计算机进行网络互联的同时,各种家电设备、仪表设备及工业中数据采集与控制设备也在逐步走向网络化,基于此结合专用的以太网控制芯片RTL8019学习了利用单片机实现以太网接口的设计。

随着互联网的迅速发展,网络用户飞速增长,在使用计算机进行网络互联的同时,各种家电设备、仪表设备及工业中数据采集与控制设备也在逐步走向网络化,基于此结合专用的以太网控制芯片RTL8019学习了利用单片机实现以太网接口的设计。

主要器件:

1、 AT89C52单片机芯片,实现对RTL8019的初始化和输入输出控制。

2、 74LS373地址锁存器。

3、 HM62256高速CMOS 8位32KB的RAM芯片。

4、 RTL8019AS高集成以太网控制器芯片。

试验电路图:

 

试验程度代码:

//Ethernet.h程序

#ifndef _ETHERNET_H // 防止Ethernet.h被重复引用

#define _ETHERNET_H

#include // 引用标准库的头文件

#include

#include

#define uchar unsigned char

#define uint unsigned int

#define REG00 XBYTE[0x8000] // 端口300H,命令寄存器CR

#define REG01 XBYTE[0x8001] // 端口301H

#define REG02 XBYTE[0x8002] // 端口302H

#define REG03 XBYTE[0x8003] // 端口303H

#define REG04 XBYTE[0x8004] // 端口304H

#define REG05 XBYTE[0x8005] // 端口305H

#define REG06 XBYTE[0x8006] // 端口306H

#define REG07 XBYTE[0x8007] // 端口307H

#define REG08 XBYTE[0x8000] // 端口308H

#define REG09 XBYTE[0x8001] // 端口309H

#define REG0a XBYTE[0x800a] // 端口30aH

#define REG0b XBYTE[0x800b] // 端口30bH

#define REG0c XBYTE[0x800c] // 端口30cH

#define REG0d XBYTE[0x800d] // 端口30dH

#define REG0e XBYTE[0x800e] // 端口30eH

#define REG0f XBYTE[0x800f] // 端口30fH

#define REG10 XBYTE[0x8010] // 端口310H

#define REG11 XBYTE[0x8011] // 端口311H

#define REG12 XBYTE[0x8012] // 端口312H

#define REG13 XBYTE[0x8013] // 端口313H

#define REG14 XBYTE[0x8014] // 端口314H

#define REG15 XBYTE[0x8015] // 端口315H

#define REG16 XBYTE[0x8016] // 端口316H

#define REG17 XBYTE[0x8017] // 端口317H

#define REG18 XBYTE[0x8010] // 端口318H

#define REG19 XBYTE[0x8011] // 端口319H

#define REG1a XBYTE[0x801a] // 端口31aH

#define REG1b XBYTE[0x801b] // 端口31bH

#define REG1c XBYTE[0x801c] // 端口31cH

#define REG1d XBYTE[0x801d] // 端口31dH

#define REG1e XBYTE[0x801e] // 端口31eH

#define REG1f XBYTE[0x801f] // 端口31fH

void delay(uint t);

void NICRst();

void SelectPage(uchar pagenum);

void ClearISR();

void GetPhyAdd();

void RTL8019Init();

#endif

//Ethernet.c程序

#include "Ethernet.h"

/* 主函数 */

void main(void)

{

delay(1000); // 延时1s,保证电源稳定和网卡自身的上电完成

NICRst(); // RTL8019AS热复位

ClearISR(); // 清除ISR寄存器

RTL8019Init(); // 初始化RTL8019AS

while(1)

{

;

}

}

/* 延时t毫秒 */

void delay(uint t)

{

uint i;

while(t--)

{

/* 对于12M时钟,约延时1ms */

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

{}

}

}

/* RTL8019AS热复位 */

void NICRst()

{

uchar i,tmp;

tmp = REG1f; // 读RTL8019AS的复位端口

REG1f = tmp; // 写RTL8019AS的复位端口

for(i=0;i<250;i++); // 适当延时

}

/* 通过CR寄存器的PS1和PS0设置寄存器页 */

void SelectPage(uchar pagenum)

{

uchar tmp;

tmp = REG00;

tmp = tmp&0x3B; // 注意不是0x3F,TXP位在不发送时要置0

pagenum = pagenum<<6;

tmp = tmp|pagenum;

REG00 = tmp;

}

接上篇程序代码:

/* 初始化RTL8019AS,PAGE2寄存器只读,PAGE3寄存器不是NE2000兼容的,均不用设置 */

/* 使用0x40-0x4b为网卡的发送缓冲区,共12页,刚好存储2个最大的以太网数据包。

使用0x4c-0x7f为网卡的接收缓冲区,共52页。因此PSTART=0x4c,PSTOP=0x80

(0x80为停止页,接收缓冲区直到0x7f,不包括0x80)。刚开始时,网卡没有接收

到任何数据包,因此BNRY设置为指向第一个接收缓冲区的页0x4c) */

void RTL8019Init()

{

REG00 = 0x21; // 选择页0的寄存器,网卡停止运行,因为还没有初始化

REG01 = 0x4c; // 寄存器PSTART,设置接收缓冲区的起始页的地址

REG02 = 0x80; // 寄存器PSTOP,设置接收缓冲区的结束页的地址

REG03 = 0x4c; // 寄存器BNRY,设置为指向第一个接收缓冲区的页0x4c(用作读指针)

REG04 = 0x40; // 寄存器TPSR,发送起始页地址初始化为指向第一个发送缓冲区的页

REG0c = 0xcc; /* 接收配置寄存器RCR,设置为仅接收自己地址的数据包以及广播地址

和多点播送地址数据包,小于64字节的包丢弃,校验错的数据包不接收 */

REG0d = 0xe0; // 发送配置寄存器TCR,设置为启用crc自动生成和校验,正常模式工作

REG0e = 0xc8; /* 数据配置寄存器DCR,设置为使用FIFO缓存,普通模式,8位数据传输,

字节顺序为高位字节在前,低位字节在后 */

REG0f = 0x00; // 中断屏蔽寄存器IMR,设置为屏蔽所有中断

SelectPage(1); // 选择页1的寄存器

REG07=0x4d; // 寄存器CURR,设置为指向当前正在写的页的下一页(用作写指针)

/* 多址地址寄存器MAR0-MAR7均设置为0x00 */

REG08 = 0x00; // MAR0

REG09 = 0x00; // MAR1

REG0a = 0x00; // MAR2

REG0b = 0x80; // MAR3

REG0c = 0x00; // MAR4

REG0d = 0x00; // MAR5

REG0e = 0x00; // MAR6

REG0f = 0x00; // MAR7

GetPhyAdd(); // 获取以太网物理地址

REG00 = 0x22; // 选择页0寄存器,执行命令。

}

/* 上电后清除ISR寄存器 */

void ClearISR()

{

SelectPage(0);

REG07 = REG07|0xff;

}

/* 获取以太网物理地址 */

void GetPhyAdd()

{

uchar tmp;

SelectPage(0); // 选择页0

REG08 = 0; // 远程DMA起始地址低位寄存器RSAR0,设置为0

REG09 = 0; // 远程DMA起始地址高位寄存器RSAR1,设置为0

REG0a = 12; // 远程DMA计数器低位寄存器RBCR0,设置为12

REG0b = 0; // 远程DMA计数器高位寄存器RBCR1,设置为0

REG00 = 0x0a; // 远程DMA,启动命令

SelectPage(1); // 选择页1

tmp = REG10; // 读取一个字节

REG01 = tmp; // 写入PAR0

tmp = REG10; // 读取一个重复的字节,这个字节被丢弃

tmp = REG10; // 读取一个字节

REG02 = tmp; // 写入PAR1

tmp = REG10; // 读取一个重复的字节,这个字节被丢弃

tmp = REG10; // 读取一个字节

REG03 = tmp; // 写入PAR2

tmp = REG10; // 读取一个重复的字节,这个字节被丢弃

tmp = REG10; // 读取一个字节

REG04 = tmp; // 写入PAR3

tmp = REG10; // 读取一个重复的字节,这个字节被丢弃

tmp = REG10; // 读取一个字节

REG05 = tmp; // 写入PAR4

tmp = REG10; // 读取一个重复的字节,这个字节被丢弃

tmp = REG10; // 读取一个字节

REG06 = tmp; // 写入PAR5

}

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭