aboutsummaryrefslogtreecommitdiff
path: root/drivers/rtl8019.h
blob: 38116ad8457c2d3ca9a2d420c776255cb81b1f20 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
/*
 * Realtek 8019AS Ethernet
 * (C) Copyright 2002-2003
 * Xue Ligong(lgxue@hotmail.com),Wang Kehao, ESLAB, whut.edu.cn
 *
 * See file CREDITS for list of people who contributed to this
 * project.
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License as
 * published by the Free Software Foundation; either version 2 of
 * the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
 * MA 02111-1307 USA
 */

/*
 * This code works in 8bit mode.
 * If you need to work in 16bit mode, PLS change it!
 */

#include <asm/types.h>
#include <config.h>


#ifdef CONFIG_DRIVER_RTL8019

#define		RTL8019_REG_00        		(RTL8019_BASE + 0x00)
#define 	RTL8019_REG_01        		(RTL8019_BASE + 0x01)
#define 	RTL8019_REG_02        		(RTL8019_BASE + 0x02)
#define 	RTL8019_REG_03        		(RTL8019_BASE + 0x03)
#define 	RTL8019_REG_04        		(RTL8019_BASE + 0x04)
#define 	RTL8019_REG_05        		(RTL8019_BASE + 0x05)
#define 	RTL8019_REG_06        		(RTL8019_BASE + 0x06)
#define 	RTL8019_REG_07        		(RTL8019_BASE + 0x07)
#define 	RTL8019_REG_08        		(RTL8019_BASE + 0x08)
#define 	RTL8019_REG_09        		(RTL8019_BASE + 0x09)
#define 	RTL8019_REG_0a        		(RTL8019_BASE + 0x0a)
#define 	RTL8019_REG_0b        		(RTL8019_BASE + 0x0b)
#define 	RTL8019_REG_0c        		(RTL8019_BASE + 0x0c)
#define 	RTL8019_REG_0d        		(RTL8019_BASE + 0x0d)
#define 	RTL8019_REG_0e       	 	(RTL8019_BASE + 0x0e)
#define 	RTL8019_REG_0f        		(RTL8019_BASE + 0x0f)
#define 	RTL8019_REG_10        		(RTL8019_BASE + 0x10)
#define 	RTL8019_REG_1f        		(RTL8019_BASE + 0x1f)

#define		RTL8019_COMMAND			RTL8019_REG_00
#define		RTL8019_PAGESTART		RTL8019_REG_01
#define		RTL8019_PAGESTOP		RTL8019_REG_02
#define		RTL8019_BOUNDARY		RTL8019_REG_03
#define		RTL8019_TRANSMITSTATUS		RTL8019_REG_04
#define		RTL8019_TRANSMITPAGE		RTL8019_REG_04
#define		RTL8019_TRANSMITBYTECOUNT0	RTL8019_REG_05
#define		RTL8019_NCR 			RTL8019_REG_05
#define		RTL8019_TRANSMITBYTECOUNT1 	RTL8019_REG_06
#define		RTL8019_INTERRUPTSTATUS		RTL8019_REG_07
#define		RTL8019_CURRENT 		RTL8019_REG_07
#define		RTL8019_REMOTESTARTADDRESS0 	RTL8019_REG_08
#define		RTL8019_CRDMA0  		RTL8019_REG_08
#define		RTL8019_REMOTESTARTADDRESS1 	RTL8019_REG_09
#define		RTL8019_CRDMA1 			RTL8019_REG_09
#define		RTL8019_REMOTEBYTECOUNT0	RTL8019_REG_0a
#define		RTL8019_REMOTEBYTECOUNT1	RTL8019_REG_0b
#define		RTL8019_RECEIVESTATUS		RTL8019_REG_0c
#define		RTL8019_RECEIVECONFIGURATION	RTL8019_REG_0c
#define		RTL8019_TRANSMITCONFIGURATION	RTL8019_REG_0d
#define		RTL8019_FAE_TALLY 		RTL8019_REG_0d
#define		RTL8019_DATACONFIGURATION	RTL8019_REG_0e
#define		RTL8019_CRC_TALLY 		RTL8019_REG_0e
#define		RTL8019_INTERRUPTMASK		RTL8019_REG_0f
#define		RTL8019_MISS_PKT_TALLY		RTL8019_REG_0f
#define		RTL8019_PHYSICALADDRESS0	RTL8019_REG_01
#define 	RTL8019_PHYSICALADDRESS1	RTL8019_REG_02
#define		RTL8019_PHYSICALADDRESS2	RTL8019_REG_03
#define		RTL8019_PHYSICALADDRESS3	RTL8019_REG_04
#define		RTL8019_PHYSICALADDRESS4	RTL8019_REG_05
#define		RTL8019_PHYSICALADDRESS5	RTL8019_REG_06
#define		RTL8019_MULTIADDRESS0		RTL8019_REG_08
#define		RTL8019_MULTIADDRESS1		RTL8019_REG_09
#define		RTL8019_MULTIADDRESS2		RTL8019_REG_0a
#define		RTL8019_MULTIADDRESS3		RTL8019_REG_0b
#define		RTL8019_MULTIADDRESS4		RTL8019_REG_0c
#define		RTL8019_MULTIADDRESS5		RTL8019_REG_0d
#define		RTL8019_MULTIADDRESS6		RTL8019_REG_0e
#define		RTL8019_MULTIADDRESS7		RTL8019_REG_0f
#define		RTL8019_DMA_DATA		RTL8019_REG_10
#define		RTL8019_RESET			RTL8019_REG_1f


#define 	RTL8019_PAGE0               	0x22
#define   	RTL8019_PAGE1               	0x62
#define   	RTL8019_PAGE0DMAWRITE       	0x12
#define   	RTL8019_PAGE2DMAWRITE       	0x92
#define   	RTL8019_REMOTEDMAWR         	0x12
#define   	RTL8019_REMOTEDMARD         	0x0A
#define   	RTL8019_ABORTDMAWR          	0x32
#define   	RTL8019_ABORTDMARD          	0x2A
#define   	RTL8019_PAGE0STOP           	0x21
#define   	RTL8019_PAGE1STOP           	0x61
#define   	RTL8019_TRANSMIT            	0x26
#define   	RTL8019_TXINPROGRESS        	0x04
#define   	RTL8019_SEND		    	0x1A

#define		RTL8019_PSTART			0x4c
#define		RTL8019_PSTOP			0x80
#define		RTL8019_TPSTART			0x40


#endif /*end of CONFIG_DRIVER_RTL8019*/