#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字节的包丢弃,校验错的数据包不接收 */