]> git.sur5r.net Git - freertos/blob - Demo/CORTEX_LPC1768_GCC_Rowley/webserver/EthDev_LPC17xx.h
Start to re-arrange files to include FreeRTOS+ in main download.
[freertos] / Demo / CORTEX_LPC1768_GCC_Rowley / webserver / EthDev_LPC17xx.h
1 /*\r
2  * @file:    EthDev_LPC17xx.h\r
3  * @purpose: Ethernet Device Definitions for NXP LPC17xx\r
4  * @version: V0.01\r
5  * @date:    14. May 2009\r
6  *----------------------------------------------------------------------------\r
7  *\r
8  * Copyright (C) 2009 ARM Limited. All rights reserved.\r
9  *\r
10  * ARM Limited (ARM) is supplying this software for use with Cortex-M3\r
11  * processor based microcontrollers.  This file can be freely distributed\r
12  * within development tools that are supporting such ARM based processors.\r
13  *\r
14  * THIS SOFTWARE IS PROVIDED "AS IS".  NO WARRANTIES, WHETHER EXPRESS, IMPLIED\r
15  * OR STATUTORY, INCLUDING, BUT NOT LIMITED TO, IMPLIED WARRANTIES OF\r
16  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE.\r
17  * ARM SHALL NOT, IN ANY CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR\r
18  * CONSEQUENTIAL DAMAGES, FOR ANY REASON WHATSOEVER.\r
19  *\r
20  */\r
21 \r
22 #ifndef __ETHDEV_LPC17XX_H\r
23 #define __ETHDEV_LPC17XX_H\r
24 \r
25 #include <stdint.h>\r
26 \r
27 /* EMAC Memory Buffer configuration for 16K Ethernet RAM. */\r
28 #define NUM_RX_FRAG         3           /* Num.of RX Fragments. */\r
29 #define NUM_TX_FRAG         2           /* Num.of TX Fragments. */\r
30 #define ETH_FRAG_SIZE       1536        /* Packet Fragment size 1536 Bytes   */\r
31 \r
32 #define ETH_MAX_FLEN        1536        /* Max. Ethernet Frame Size          */\r
33 \r
34 typedef struct {                        /* RX Descriptor struct              */\r
35    uint32_t Packet;\r
36    uint32_t Ctrl;\r
37 } RX_DESC_TypeDef;\r
38 \r
39 typedef struct {                        /* RX Status struct                  */\r
40    uint32_t Info;\r
41    uint32_t HashCRC;\r
42 } RX_STAT_TypeDef;\r
43 \r
44 typedef struct {                        /* TX Descriptor struct              */\r
45    uint32_t Packet;\r
46    uint32_t Ctrl;\r
47 } TX_DESC_TypeDef;\r
48 \r
49 typedef struct {                        /* TX Status struct                  */\r
50    uint32_t Info;\r
51 } TX_STAT_TypeDef;\r
52 \r
53 \r
54 /* EMAC variables located in AHB SRAM bank 1*/\r
55 #define AHB_SRAM_BANK1_BASE  0x2007c000UL\r
56 #define RX_DESC_BASE        (AHB_SRAM_BANK1_BASE         )\r
57 #define RX_STAT_BASE        (RX_DESC_BASE + NUM_RX_FRAG*(2*4))     /* 2 * uint32_t, see RX_DESC_TypeDef */\r
58 #define TX_DESC_BASE        (RX_STAT_BASE + NUM_RX_FRAG*(2*4))     /* 2 * uint32_t, see RX_STAT_TypeDef */\r
59 #define TX_STAT_BASE        (TX_DESC_BASE + NUM_TX_FRAG*(2*4))     /* 2 * uint32_t, see TX_DESC_TypeDef */\r
60 #define ETH_BUF_BASE            (TX_STAT_BASE + NUM_TX_FRAG*(1*4))     /* 1 * uint32_t, see TX_STAT_TypeDef */\r
61 \r
62 /* RX and TX descriptor and status definitions. */\r
63 #define RX_DESC_PACKET(i)   (*(unsigned int *)(RX_DESC_BASE   + 8*i))\r
64 #define RX_DESC_CTRL(i)     (*(unsigned int *)(RX_DESC_BASE+4 + 8*i))\r
65 #define RX_STAT_INFO(i)     (*(unsigned int *)(RX_STAT_BASE   + 8*i))\r
66 #define RX_STAT_HASHCRC(i)  (*(unsigned int *)(RX_STAT_BASE+4 + 8*i))\r
67 #define TX_DESC_PACKET(i)   (*(unsigned int *)(TX_DESC_BASE   + 8*i))\r
68 #define TX_DESC_CTRL(i)     (*(unsigned int *)(TX_DESC_BASE+4 + 8*i))\r
69 #define TX_STAT_INFO(i)     (*(unsigned int *)(TX_STAT_BASE   + 4*i))\r
70 #define ETH_BUF(i)          ( ETH_BUF_BASE + ETH_FRAG_SIZE*i )\r
71 #define ETH_NUM_BUFFERS         ( NUM_TX_FRAG + NUM_RX_FRAG + 1 ) /* There are in fact 2 more buffers than descriptors as the two Tx descriptors use the same buffer to speed up the uip Tx. */\r
72 \r
73 \r
74 /* MAC Configuration Register 1 */\r
75 #define MAC1_REC_EN         0x00000001  /* Receive Enable                    */\r
76 #define MAC1_PASS_ALL       0x00000002  /* Pass All Receive Frames           */\r
77 #define MAC1_RX_FLOWC       0x00000004  /* RX Flow Control                   */\r
78 #define MAC1_TX_FLOWC       0x00000008  /* TX Flow Control                   */\r
79 #define MAC1_LOOPB          0x00000010  /* Loop Back Mode                    */\r
80 #define MAC1_RES_TX         0x00000100  /* Reset TX Logic                    */\r
81 #define MAC1_RES_MCS_TX     0x00000200  /* Reset MAC TX Control Sublayer     */\r
82 #define MAC1_RES_RX         0x00000400  /* Reset RX Logic                    */\r
83 #define MAC1_RES_MCS_RX     0x00000800  /* Reset MAC RX Control Sublayer     */\r
84 #define MAC1_SIM_RES        0x00004000  /* Simulation Reset                  */\r
85 #define MAC1_SOFT_RES       0x00008000  /* Soft Reset MAC                    */\r
86 \r
87 /* MAC Configuration Register 2 */\r
88 #define MAC2_FULL_DUP       0x00000001  /* Full Duplex Mode                  */\r
89 #define MAC2_FRM_LEN_CHK    0x00000002  /* Frame Length Checking             */\r
90 #define MAC2_HUGE_FRM_EN    0x00000004  /* Huge Frame Enable                 */\r
91 #define MAC2_DLY_CRC        0x00000008  /* Delayed CRC Mode                  */\r
92 #define MAC2_CRC_EN         0x00000010  /* Append CRC to every Frame         */\r
93 #define MAC2_PAD_EN         0x00000020  /* Pad all Short Frames              */\r
94 #define MAC2_VLAN_PAD_EN    0x00000040  /* VLAN Pad Enable                   */\r
95 #define MAC2_ADET_PAD_EN    0x00000080  /* Auto Detect Pad Enable            */\r
96 #define MAC2_PPREAM_ENF     0x00000100  /* Pure Preamble Enforcement         */\r
97 #define MAC2_LPREAM_ENF     0x00000200  /* Long Preamble Enforcement         */\r
98 #define MAC2_NO_BACKOFF     0x00001000  /* No Backoff Algorithm              */\r
99 #define MAC2_BACK_PRESSURE  0x00002000  /* Backoff Presurre / No Backoff     */\r
100 #define MAC2_EXCESS_DEF     0x00004000  /* Excess Defer                      */\r
101 \r
102 /* Back-to-Back Inter-Packet-Gap Register */\r
103 #define IPGT_FULL_DUP       0x00000015  /* Recommended value for Full Duplex */\r
104 #define IPGT_HALF_DUP       0x00000012  /* Recommended value for Half Duplex */\r
105 \r
106 /* Non Back-to-Back Inter-Packet-Gap Register */\r
107 #define IPGR_DEF            0x00000012  /* Recommended value                 */\r
108 \r
109 /* Collision Window/Retry Register */\r
110 #define CLRT_DEF            0x0000370F  /* Default value                     */\r
111 \r
112 /* PHY Support Register */\r
113 #define SUPP_SPEED          0x00000100  /* Reduced MII Logic Current Speed   */\r
114 #define SUPP_RES_RMII       0x00000800  /* Reset Reduced MII Logic           */\r
115 \r
116 /* Test Register */\r
117 #define TEST_SHCUT_PQUANTA  0x00000001  /* Shortcut Pause Quanta             */\r
118 #define TEST_TST_PAUSE      0x00000002  /* Test Pause                        */\r
119 #define TEST_TST_BACKP      0x00000004  /* Test Back Pressure                */\r
120 \r
121 /* MII Management Configuration Register */\r
122 #define MCFG_SCAN_INC       0x00000001  /* Scan Increment PHY Address        */\r
123 #define MCFG_SUPP_PREAM     0x00000002  /* Suppress Preamble                 */\r
124 #define MCFG_CLK_SEL        0x0000003C  /* Clock Select Mask                 */\r
125 #define MCFG_RES_MII        0x00008000  /* Reset MII Management Hardware     */\r
126 \r
127 /* MII Management Command Register */\r
128 #define MCMD_READ           0x00000001  /* MII Read                          */\r
129 #define MCMD_SCAN           0x00000002  /* MII Scan continuously             */\r
130 \r
131 #define MII_WR_TOUT         0x00050000  /* MII Write timeout count           */\r
132 #define MII_RD_TOUT         0x00050000  /* MII Read timeout count            */\r
133 \r
134 /* MII Management Address Register */\r
135 #define MADR_REG_ADR        0x0000001F  /* MII Register Address Mask         */\r
136 #define MADR_PHY_ADR        0x00001F00  /* PHY Address Mask                  */\r
137 \r
138 /* MII Management Indicators Register */\r
139 #define MIND_BUSY           0x00000001  /* MII is Busy                       */\r
140 #define MIND_SCAN           0x00000002  /* MII Scanning in Progress          */\r
141 #define MIND_NOT_VAL        0x00000004  /* MII Read Data not valid           */\r
142 #define MIND_MII_LINK_FAIL  0x00000008  /* MII Link Failed                   */\r
143 \r
144 /* Command Register */\r
145 #define CR_RX_EN            0x00000001  /* Enable Receive                    */\r
146 #define CR_TX_EN            0x00000002  /* Enable Transmit                   */\r
147 #define CR_REG_RES          0x00000008  /* Reset Host Registers              */\r
148 #define CR_TX_RES           0x00000010  /* Reset Transmit Datapath           */\r
149 #define CR_RX_RES           0x00000020  /* Reset Receive Datapath            */\r
150 #define CR_PASS_RUNT_FRM    0x00000040  /* Pass Runt Frames                  */\r
151 #define CR_PASS_RX_FILT     0x00000080  /* Pass RX Filter                    */\r
152 #define CR_TX_FLOW_CTRL     0x00000100  /* TX Flow Control                   */\r
153 #define CR_RMII             0x00000200  /* Reduced MII Interface             */\r
154 #define CR_FULL_DUP         0x00000400  /* Full Duplex                       */\r
155 \r
156 /* Status Register */\r
157 #define SR_RX_EN            0x00000001  /* Enable Receive                    */\r
158 #define SR_TX_EN            0x00000002  /* Enable Transmit                   */\r
159 \r
160 /* Transmit Status Vector 0 Register */\r
161 #define TSV0_CRC_ERR        0x00000001  /* CRC error                         */\r
162 #define TSV0_LEN_CHKERR     0x00000002  /* Length Check Error                */\r
163 #define TSV0_LEN_OUTRNG     0x00000004  /* Length Out of Range               */\r
164 #define TSV0_DONE           0x00000008  /* Tramsmission Completed            */\r
165 #define TSV0_MCAST          0x00000010  /* Multicast Destination             */\r
166 #define TSV0_BCAST          0x00000020  /* Broadcast Destination             */\r
167 #define TSV0_PKT_DEFER      0x00000040  /* Packet Deferred                   */\r
168 #define TSV0_EXC_DEFER      0x00000080  /* Excessive Packet Deferral         */\r
169 #define TSV0_EXC_COLL       0x00000100  /* Excessive Collision               */\r
170 #define TSV0_LATE_COLL      0x00000200  /* Late Collision Occured            */\r
171 #define TSV0_GIANT          0x00000400  /* Giant Frame                       */\r
172 #define TSV0_UNDERRUN       0x00000800  /* Buffer Underrun                   */\r
173 #define TSV0_BYTES          0x0FFFF000  /* Total Bytes Transferred           */\r
174 #define TSV0_CTRL_FRAME     0x10000000  /* Control Frame                     */\r
175 #define TSV0_PAUSE          0x20000000  /* Pause Frame                       */\r
176 #define TSV0_BACK_PRESS     0x40000000  /* Backpressure Method Applied       */\r
177 #define TSV0_VLAN           0x80000000  /* VLAN Frame                        */\r
178 \r
179 /* Transmit Status Vector 1 Register */\r
180 #define TSV1_BYTE_CNT       0x0000FFFF  /* Transmit Byte Count               */\r
181 #define TSV1_COLL_CNT       0x000F0000  /* Transmit Collision Count          */\r
182 \r
183 /* Receive Status Vector Register */\r
184 #define RSV_BYTE_CNT        0x0000FFFF  /* Receive Byte Count                */\r
185 #define RSV_PKT_IGNORED     0x00010000  /* Packet Previously Ignored         */\r
186 #define RSV_RXDV_SEEN       0x00020000  /* RXDV Event Previously Seen        */\r
187 #define RSV_CARR_SEEN       0x00040000  /* Carrier Event Previously Seen     */\r
188 #define RSV_REC_CODEV       0x00080000  /* Receive Code Violation            */\r
189 #define RSV_CRC_ERR         0x00100000  /* CRC Error                         */\r
190 #define RSV_LEN_CHKERR      0x00200000  /* Length Check Error                */\r
191 #define RSV_LEN_OUTRNG      0x00400000  /* Length Out of Range               */\r
192 #define RSV_REC_OK          0x00800000  /* Frame Received OK                 */\r
193 #define RSV_MCAST           0x01000000  /* Multicast Frame                   */\r
194 #define RSV_BCAST           0x02000000  /* Broadcast Frame                   */\r
195 #define RSV_DRIB_NIBB       0x04000000  /* Dribble Nibble                    */\r
196 #define RSV_CTRL_FRAME      0x08000000  /* Control Frame                     */\r
197 #define RSV_PAUSE           0x10000000  /* Pause Frame                       */\r
198 #define RSV_UNSUPP_OPC      0x20000000  /* Unsupported Opcode                */\r
199 #define RSV_VLAN            0x40000000  /* VLAN Frame                        */\r
200 \r
201 /* Flow Control Counter Register */\r
202 #define FCC_MIRR_CNT        0x0000FFFF  /* Mirror Counter                    */\r
203 #define FCC_PAUSE_TIM       0xFFFF0000  /* Pause Timer                       */\r
204 \r
205 /* Flow Control Status Register */\r
206 #define FCS_MIRR_CNT        0x0000FFFF  /* Mirror Counter Current            */\r
207 \r
208 /* Receive Filter Control Register */\r
209 #define RFC_UCAST_EN        0x00000001  /* Accept Unicast Frames Enable      */\r
210 #define RFC_BCAST_EN        0x00000002  /* Accept Broadcast Frames Enable    */\r
211 #define RFC_MCAST_EN        0x00000004  /* Accept Multicast Frames Enable    */\r
212 #define RFC_UCAST_HASH_EN   0x00000008  /* Accept Unicast Hash Filter Frames */\r
213 #define RFC_MCAST_HASH_EN   0x00000010  /* Accept Multicast Hash Filter Fram.*/\r
214 #define RFC_PERFECT_EN      0x00000020  /* Accept Perfect Match Enable       */\r
215 #define RFC_MAGP_WOL_EN     0x00001000  /* Magic Packet Filter WoL Enable    */\r
216 #define RFC_PFILT_WOL_EN    0x00002000  /* Perfect Filter WoL Enable         */\r
217 \r
218 /* Receive Filter WoL Status/Clear Registers */\r
219 #define WOL_UCAST           0x00000001  /* Unicast Frame caused WoL          */\r
220 #define WOL_BCAST           0x00000002  /* Broadcast Frame caused WoL        */\r
221 #define WOL_MCAST           0x00000004  /* Multicast Frame caused WoL        */\r
222 #define WOL_UCAST_HASH      0x00000008  /* Unicast Hash Filter Frame WoL     */\r
223 #define WOL_MCAST_HASH      0x00000010  /* Multicast Hash Filter Frame WoL   */\r
224 #define WOL_PERFECT         0x00000020  /* Perfect Filter WoL                */\r
225 #define WOL_RX_FILTER       0x00000080  /* RX Filter caused WoL              */\r
226 #define WOL_MAG_PACKET      0x00000100  /* Magic Packet Filter caused WoL    */\r
227 \r
228 /* Interrupt Status/Enable/Clear/Set Registers */\r
229 #define INT_RX_OVERRUN      0x00000001  /* Overrun Error in RX Queue         */\r
230 #define INT_RX_ERR          0x00000002  /* Receive Error                     */\r
231 #define INT_RX_FIN          0x00000004  /* RX Finished Process Descriptors   */\r
232 #define INT_RX_DONE         0x00000008  /* Receive Done                      */\r
233 #define INT_TX_UNDERRUN     0x00000010  /* Transmit Underrun                 */\r
234 #define INT_TX_ERR          0x00000020  /* Transmit Error                    */\r
235 #define INT_TX_FIN          0x00000040  /* TX Finished Process Descriptors   */\r
236 #define INT_TX_DONE         0x00000080  /* Transmit Done                     */\r
237 #define INT_SOFT_INT        0x00001000  /* Software Triggered Interrupt      */\r
238 #define INT_WAKEUP          0x00002000  /* Wakeup Event Interrupt            */\r
239 \r
240 /* Power Down Register */\r
241 #define PD_POWER_DOWN       0x80000000  /* Power Down MAC                    */\r
242 \r
243 /* RX Descriptor Control Word */\r
244 #define RCTRL_SIZE          0x000007FF  /* Buffer size mask                  */\r
245 #define RCTRL_INT           0x80000000  /* Generate RxDone Interrupt         */\r
246 \r
247 /* RX Status Hash CRC Word */\r
248 #define RHASH_SA            0x000001FF  /* Hash CRC for Source Address       */\r
249 #define RHASH_DA            0x001FF000  /* Hash CRC for Destination Address  */\r
250 \r
251 /* RX Status Information Word */\r
252 #define RINFO_SIZE          0x000007FF  /* Data size in bytes                */\r
253 #define RINFO_CTRL_FRAME    0x00040000  /* Control Frame                     */\r
254 #define RINFO_VLAN          0x00080000  /* VLAN Frame                        */\r
255 #define RINFO_FAIL_FILT     0x00100000  /* RX Filter Failed                  */\r
256 #define RINFO_MCAST         0x00200000  /* Multicast Frame                   */\r
257 #define RINFO_BCAST         0x00400000  /* Broadcast Frame                   */\r
258 #define RINFO_CRC_ERR       0x00800000  /* CRC Error in Frame                */\r
259 #define RINFO_SYM_ERR       0x01000000  /* Symbol Error from PHY             */\r
260 #define RINFO_LEN_ERR       0x02000000  /* Length Error                      */\r
261 #define RINFO_RANGE_ERR     0x04000000  /* Range Error (exceeded max. size)  */\r
262 #define RINFO_ALIGN_ERR     0x08000000  /* Alignment Error                   */\r
263 #define RINFO_OVERRUN       0x10000000  /* Receive overrun                   */\r
264 #define RINFO_NO_DESCR      0x20000000  /* No new Descriptor available       */\r
265 #define RINFO_LAST_FLAG     0x40000000  /* Last Fragment in Frame            */\r
266 #define RINFO_ERR           0x80000000  /* Error Occured (OR of all errors)  */\r
267 \r
268 #define RINFO_ERR_MASK     (RINFO_FAIL_FILT | RINFO_CRC_ERR   | RINFO_SYM_ERR | \\r
269                             RINFO_LEN_ERR   | RINFO_ALIGN_ERR | RINFO_OVERRUN)\r
270 \r
271 /* TX Descriptor Control Word */\r
272 #define TCTRL_SIZE          0x000007FF  /* Size of data buffer in bytes      */\r
273 #define TCTRL_OVERRIDE      0x04000000  /* Override Default MAC Registers    */\r
274 #define TCTRL_HUGE          0x08000000  /* Enable Huge Frame                 */\r
275 #define TCTRL_PAD           0x10000000  /* Pad short Frames to 64 bytes      */\r
276 #define TCTRL_CRC           0x20000000  /* Append a hardware CRC to Frame    */\r
277 #define TCTRL_LAST          0x40000000  /* Last Descriptor for TX Frame      */\r
278 #define TCTRL_INT           0x80000000  /* Generate TxDone Interrupt         */\r
279 \r
280 /* TX Status Information Word */\r
281 #define TINFO_COL_CNT       0x01E00000  /* Collision Count                   */\r
282 #define TINFO_DEFER         0x02000000  /* Packet Deferred (not an error)    */\r
283 #define TINFO_EXCESS_DEF    0x04000000  /* Excessive Deferral                */\r
284 #define TINFO_EXCESS_COL    0x08000000  /* Excessive Collision               */\r
285 #define TINFO_LATE_COL      0x10000000  /* Late Collision Occured            */\r
286 #define TINFO_UNDERRUN      0x20000000  /* Transmit Underrun                 */\r
287 #define TINFO_NO_DESCR      0x40000000  /* No new Descriptor available       */\r
288 #define TINFO_ERR           0x80000000  /* Error Occured (OR of all errors)  */\r
289 \r
290 /* ENET Device Revision ID */\r
291 #define OLD_EMAC_MODULE_ID  0x39022000  /* Rev. ID for first rev '-'         */\r
292 \r
293 /* DP83848C PHY Registers */\r
294 #define PHY_REG_BMCR        0x00        /* Basic Mode Control Register       */\r
295 #define PHY_REG_BMSR        0x01        /* Basic Mode Status Register        */\r
296 #define PHY_REG_IDR1        0x02        /* PHY Identifier 1                  */\r
297 #define PHY_REG_IDR2        0x03        /* PHY Identifier 2                  */\r
298 #define PHY_REG_ANAR        0x04        /* Auto-Negotiation Advertisement    */\r
299 #define PHY_REG_ANLPAR      0x05        /* Auto-Neg. Link Partner Abitily    */\r
300 #define PHY_REG_ANER        0x06        /* Auto-Neg. Expansion Register      */\r
301 #define PHY_REG_ANNPTR      0x07        /* Auto-Neg. Next Page TX            */\r
302 \r
303 /* PHY Extended Registers */\r
304 #define PHY_REG_STS         0x10        /* Status Register                   */\r
305 #define PHY_REG_MICR        0x11        /* MII Interrupt Control Register    */\r
306 #define PHY_REG_MISR        0x12        /* MII Interrupt Status Register     */\r
307 #define PHY_REG_FCSCR       0x14        /* False Carrier Sense Counter       */\r
308 #define PHY_REG_RECR        0x15        /* Receive Error Counter             */\r
309 #define PHY_REG_PCSR        0x16        /* PCS Sublayer Config. and Status   */\r
310 #define PHY_REG_RBR         0x17        /* RMII and Bypass Register          */\r
311 #define PHY_REG_LEDCR       0x18        /* LED Direct Control Register       */\r
312 #define PHY_REG_PHYCR       0x19        /* PHY Control Register              */\r
313 #define PHY_REG_10BTSCR     0x1A        /* 10Base-T Status/Control Register  */\r
314 #define PHY_REG_CDCTRL1     0x1B        /* CD Test Control and BIST Extens.  */\r
315 #define PHY_REG_EDCR        0x1D        /* Energy Detect Control Register    */\r
316 \r
317 #define PHY_FULLD_100M      0x2100      /* Full Duplex 100Mbit               */\r
318 #define PHY_HALFD_100M      0x2000      /* Half Duplex 100Mbit               */\r
319 #define PHY_FULLD_10M       0x0100      /* Full Duplex 10Mbit                */\r
320 #define PHY_HALFD_10M       0x0000      /* Half Duplex 10MBit                */\r
321 #define PHY_AUTO_NEG        0x3000      /* Select Auto Negotiation           */\r
322 #define PHY_AUTO_NEG_COMPLETE 0x0020    /* Auto negotiation have finished.   */\r
323 \r
324 #define DP83848C_DEF_ADR    0x0100      /* Default PHY device address        */\r
325 #define DP83848C_ID         0x20005C90  /* PHY Identifier                    */\r
326 \r
327 #endif\r
328 \r
329 /*----------------------------------------------------------------------------\r
330  * end of file\r
331  *---------------------------------------------------------------------------*/\r