OpenCores
URL https://opencores.org/ocsvn/minsoc/minsoc/trunk

Subversion Repositories minsoc

[/] [minsoc/] [trunk/] [sw/] [drivers/] [eth.h] - Rev 106

Go to most recent revision | Compare with Previous | Blame | View Log

void eth_init();
void eth_interrupt();
void eth_recv_ack(void);
 
int eth_send(int length);   //return (-1) or length (still processing previous) or asserted
 
#define ETH_MODER		0x00
#define ETH_INT_SOURCE		0x04
#define ETH_INT_MASK		0x08
#define ETH_IPGT		0x0C
#define ETH_IPGR1		0x10
#define ETH_IPGR2		0x14
#define ETH_PACKETLEN		0x18
#define ETH_COLLCONF		0x1C
#define ETH_TX_BD_NUM		0x20
#define ETH_CTRLMODER		0x24
#define ETH_MIIMODER		0x28
#define ETH_MIICOMMAND		0x2C
#define ETH_MIIADDRESS		0x30
#define ETH_MIITX_DATA		0x34
#define ETH_MIIRX_DATA		0x38
#define ETH_MIISTATUS		0x3C
#define ETH_MAC_ADDR0		0x40
#define ETH_MAC_ADDR1		0x44
#define ETH_HASH0_ADR		0x48
#define ETH_HASH1_ADR		0x4C
#define ETH_TXCTRL	        0x50
 
#define ETH_TXBD0H	        0x404
#define ETH_TXBD0L	        0x400
 
#define ETH_RXBD0H	        0x604	//this depends on TX_BD_NUM but this is the standard value
#define ETH_RXBD0L	        0x600	//this depends on TX_BD_NUM but this is the standard value
 
//MODER BITS
#define ETH_RECSMAL		0x00010000
#define ETH_PAD		        0x00008000
#define ETH_HUGEN	        0x00004000
#define ETH_CRCEN	        0x00002000
#define ETH_DLYCRCEN	        0x00001000
#define ETH_FULLD	        0x00000400
#define ETH_EXDFREN	        0x00000200
#define ETH_NOBCKOF	        0x00000100
#define ETH_LOOPBCK	        0x00000080
#define ETH_IFG		        0x00000040
#define ETH_PRO		        0x00000020
#define ETH_IAM		        0x00000010
#define ETH_BRO		        0x00000008
#define ETH_NOPRE	        0x00000004
#define ETH_TXEN	        0x00000002
#define ETH_RXEN	        0x00000001
 
//INTERRUPTS BITS
#define ETH_RXC		        0x00000040
#define ETH_TXC		        0x00000020
#define ETH_BUSY	        0x00000010
#define ETH_RXE		        0x00000008
#define ETH_RXB		        0x00000004
#define ETH_TXE		        0x00000002
#define ETH_TXB		        0x00000001
 
//BUFFER DESCRIPTOR BITS
#define ETH_RXBD_EMPTY	    	0x00008000
#define ETH_RXBD_IRQ	    	0x00004000
#define ETH_RXBD_WRAP	    	0x00002000
#define ETH_RXBD_CF	        0x00000100
#define ETH_RXBD_MISS	    	0x00000080
#define ETH_RXBD_OR	        0x00000040
#define ETH_RXBD_IS	        0x00000020
#define ETH_RXBD_DN	        0x00000010
#define ETH_RXBD_TL	        0x00000008
#define ETH_RXBD_SF	        0x00000004
#define ETH_RXBD_CRC	    	0x00000002
#define ETH_RXBD_LC	        0x00000001
 
#define ETH_TXBD_READY		0x00008000
#define ETH_TXBD_IRQ		0x00004000
#define ETH_TXBD_WRAP		0x00002000
#define ETH_TXBD_PAD		0x00001000
#define ETH_TXBD_CRC		0x00000800
#define ETH_TXBD_UR	        0x00000100
#define ETH_TXBD_RL	        0x00000008
#define ETH_TXBD_LC	        0x00000004
#define ETH_TXBD_DF	        0x00000002
#define ETH_TXBD_CS	        0x00000001
 
//user defines
#define OWN_MAC_ADDRESS_5	0x55
#define OWN_MAC_ADDRESS_4	0x47
#define OWN_MAC_ADDRESS_3	0x34
#define OWN_MAC_ADDRESS_2	0x22
#define OWN_MAC_ADDRESS_1	0x88
#define OWN_MAC_ADDRESS_0	0x92
 
#define BROADCAST_ADDRESS_5	0xFF
#define BROADCAST_ADDRESS_4	0xFF
#define BROADCAST_ADDRESS_3	0xFF
#define BROADCAST_ADDRESS_2	0xFF
#define BROADCAST_ADDRESS_1	0xFF
#define BROADCAST_ADDRESS_0	0xFF
 
#define HDR_LEN			14
#define CRC_LEN			4
#define BD_SND  ( ETH_TXBD_READY | ETH_TXBD_IRQ | ETH_TXBD_WRAP | ETH_TXBD_PAD | ETH_TXBD_CRC )
#define RX_READY    ( ETH_RXBD_EMPTY | ETH_RXBD_IRQ | ETH_RXBD_WRAP )
#define TX_READY ( ETH_TXBD_IRQ | ETH_TXBD_WRAP | ETH_TXBD_PAD | ETH_TXBD_CRC )
 
//~user defines
 

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.