⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mac.c

📁 移植到440 下的uip
💻 C
字号:
/*修改说明:加高电压后,去掉了SetRegPage中判断net_start标志*/

#include "DataType.h"
#include "mac.h"
#include "Rtl8019.h"

#define	DEBUG_NET	
#define	RPSTART	0x4c
#define	RPSTOP	0x80
#define	SPSTART	0x40

static u8_t rBNRY;
static u8_t SrcMacID[6] = {0x00,0xbd,0x3b,0x33,0x05,0x71};
//static u8_t DstMacID[ETH_ALEN];

static u8_t net_start;

void SetRegPage(u8_t PageIdx)
{
	u8_t temp;
	
	temp = inportb(BaseAddr);	
//	temp = (temp&(0x3a|net_start))|(PageIdx<<6);	//ensure bit0 clear!!!
	temp = (temp&0x3b)|(PageIdx<<6);						
	outportb(BaseAddr, temp);
}
/*
static void ClearRam()
{
	int i;
	SetRegPage(0);
	outport(RSAR0, 0x4000);
	outport(RBCR0, 256*32);
	outportb(BaseAddr, 0x12);
	for(i=0; i<256*26; i++)
		outportb(RWPORT, 0x0);
}

static void ReadMacID()
{	
	SetRegPage(1);
	
	SrcMacID[0]=inportb(PAR0);
	SrcMacID[1]=inportb(PAR1);
	SrcMacID[2]=inportb(PAR2);
	SrcMacID[3]=inportb(PAR3);
	SrcMacID[4]=inportb(PAR4);
	SrcMacID[5]=inportb(PAR5);
}
*/
static void SetMacID()
{	
	SetRegPage(1);
	
	outportb(PAR0, SrcMacID[0]);
	outportb(PAR1, SrcMacID[1]);
	outportb(PAR2, SrcMacID[2]);
	outportb(PAR3, SrcMacID[3]);
	outportb(PAR4, SrcMacID[4]);
	outportb(PAR5, SrcMacID[5]);
}

static u8_t Rst8019()
{
	int i;
	
	outportb(RstAddr, 0x5a);
	i = 20000;
	while(i--);
	SetRegPage(0);
	return (inportb(ISR)&0x80);
}

static void WakeRtl8019as()
{
	SetRegPage(3);	
	outportb(CR9346, 0xcf);		//set eem1-0, 11 ,enable write config register
	outportb(CONFIG3, 0x70);	//clear pwrdn, sleep mode, set led0 as led_link, led1 as led_rx	
	outportb(CR9346, 0x3f); 	//disable write config register
}

static void InitRS8019()
{
	net_start = 1;
	outportb(BaseAddr, 0x21);	/* set page 0 and stop */
	outportb(Pstart, RPSTART);		/* set Pstart 0x4c */
	outportb(Pstop, RPSTOP);		/* set Pstop 0x80 */
	outportb(BNRY, RPSTART);	/* BNRY-> the last page has been read */	
	outportb(TPSR, SPSTART);		/* transmit page start register, 0x40 */
	outportb(RCR, 0xcc);		/* set RCR 0xcc */	
	outportb(TCR, 0xe0);		/* set TCR 0xe0 */
	outportb(DCR, 0xc8);		/* 8bit DMA */
	outportb(IMR, 0x03);		/* set IMR 0x03 */
	outportb(ISR, 0xff);	
	
	SetRegPage(1);	
	outportb(CURR, RPSTART+1);	
	outportb(MAR0, 0x00);
	outportb(MAR1, 0x41);
	outportb(MAR2, 0x00);
	outportb(MAR3, 0x80);
	outportb(MAR4, 0x00);
	outportb(MAR5, 0x00);
	outportb(MAR6, 0x00);
	outportb(MAR7, 0x00);
	outportb(BaseAddr, 0x22);	/* set page 0 and start */
	
	net_start = 0;	
	rBNRY = RPSTART;
}

int s3c44b0_eth_init(void)
{	
	int i;
	
	WakeRtl8019as();
	
	if(!Rst8019())
	{
//		puts("Rtl8019 Reset Failed!\n");
//		printf("%x ", inportb(ISR));		
//		return -1;
	}
//	puts("Rtl8019 Reset Successfully\n");		
		
	InitRS8019();
	
	i  = inportb(ID8019L);	
	i |= inportb(ID8019H)<<8;
	
	SetMacID();	
	
/*		//a test for arp request			
		while(1)	
		{
			int i;
			u8_t data[80];
			
			for(i = 0; i<6; i++)
				data[i] = 0xff;				
			for(; i<12; i++)
				data[i] = SrcMacID[i-6];
				
			data[i++] = 8;
			data[i++] = 6;
			data[i++] = 0;
			data[i++] = 1;
			data[i++] = 8;
			data[i++] = 0;
			data[i++] = 6;
			data[i++] = 4;
			data[i++] = 0;
			data[i++] = 1;
			
			for(; i<28; i++)
				data[i] = SrcMacID[i-22];
				
			data[i++] = 0xc0;
			data[i++] = 0xa8;
			data[i++] = 0xa8;
			data[i++] = 0x65;
			
			for(; i<38; i++)
				data[i] = 0;
				
			data[i++] = 0xc0;
			data[i++] = 0xa8;
			data[i++] = 0xa8;
			data[i++] = 0x64;				
			
			s3c44b0_eth_send(data, 60);
			getch();			
		}				
*/			
/*	while(1)
	{
		int i;
		static int q = 0;
		u8_t data[80];
		
		q++;
		for(i=0; i<60; i++)
			if(q&1)
				data[i] = i;
			else
				data[i] = 60-i;
				
		s3c44b0_eth_send(data, 60);
		getch();		
		//outportb(BaseAddr, 0x22);				
	}
*/
	return 0;			
}

int s3c44b0_eth_send(unsigned char *data, unsigned int len)
{
	static sFlag = 0;
	int i;
	u8_t send_page;
	
	send_page  = SPSTART;
	send_page += (sFlag&1)?6:0;
	sFlag++;			
		
	if(len<60)	
		for(; len<60; len++)
			data[len] = 0x20;		//just for pad, any data										
	
	SetRegPage(0);
	outportb(BaseAddr, 0x22);
	outportb(RSAR0, 0);
	outportb(RSAR1, send_page);
	outportb(RBCR0, len&0xff);
	outportb(RBCR1, len>>8);		
	outportb(BaseAddr, 0x12);
	for(i=0; i<len; i++)
		outportb(RWPORT, data[i]);		// tarns to ram			
	while(inportb(BaseAddr)&4);
	outportb(TPSR, send_page);
	outportb(TBCR0, len&0xff);
	outportb(TBCR1, len>>8);
	outportb(BaseAddr, 0x1e);			// begin to send

	return 0;
}

unsigned int s3c44b0_eth_rcv(unsigned char *data, unsigned int len)
{
	u8_t RxPageBeg, RxPageEnd;
	u8_t RxNextPage;
	u8_t RxStatus;
	int i, RxLength;
	U16 *data_16;
	unsigned int ret;
	
	data_16 = (U16 *)data;
	
	SetRegPage(0);
		outportb(BNRY, rBNRY);	//???
	if(inportb(ISR)&1)			//接收成功
		outportb(ISR, 0x1);		//清除中断标志
	else
		return 0;
		
	SetRegPage(1);
	RxPageEnd = inportb(CURR);
	SetRegPage(0);
	/*
	RxPageBeg = inportb(BNRY)+1;
	if(RxPageBeg>=RPSTOP)
		RxPageBeg = RPSTART;
		
	if(RxPageBeg==RxPageEnd)
		return -1;			//no data received
	*/
	RxPageBeg = rBNRY+1;
	if(RxPageBeg>=RPSTOP)
		RxPageBeg = RPSTART;
	outportb(BaseAddr, 0x22);
		
	//outport(RSAR0, RxPageBeg<<8);
	//outport(RBCR0, 256);
	outportb(RSAR0, 0);
	outportb(RSAR1, RxPageBeg);
	outportb(RBCR0, 4);
	outportb(RBCR1, 0);
	outportb(BaseAddr, 0xa);

	RxStatus   = inportb(RWPORT);
	RxNextPage = inportb(RWPORT);	
	RxLength   = inportb(RWPORT);
	RxLength  |= inportb(RWPORT)<<8;
	

//		printf("\nRxBeg = %x, RxEnd = %x, staus = %x, nextpage = %x,  size = %x", RxPageBeg, RxPageEnd, RxStatus, RxNextPage, RxLength);
//		printf("\nbeg=%x,len=%x",  RxPageBeg, RxLength);
		
        ret=RxLength=RxLength-4;
        
	if(RxLength>1514)
	{
		if(RxPageEnd==RPSTART)
			rBNRY = RPSTOP-1;
		else
			rBNRY = RxPageEnd-1;
		outportb(BNRY, rBNRY);
		return 0;
	}
	outportb(RSAR0, 4);
	outportb(RSAR1, RxPageBeg);
	outportb(RBCR0, RxLength);
	outportb(RBCR1, RxLength>>8);	
	outportb(BaseAddr, 0xa);

	i     = 0;
//	data -= i;
	for(; RxLength--;)
	{
		if(!((i+4)&0xff))
			{
				outportb(BNRY, RxPageBeg);				
				RxPageBeg++;
				if(RxPageBeg>=RPSTOP)
					RxPageBeg = RPSTART;					
			}
		data[i++] = inportb(RWPORT);		
	}
	outportb(BNRY, RxPageBeg);	
	rBNRY = RxPageBeg;
	
	return ret;		
}

int s3c44b0_eth_get_addr(unsigned char *addr)
{
	memcpy(addr, SrcMacID, 6);
	return 0;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -