2 * Copyright (c) 2006 M. Warner Losh. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
13 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
14 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
15 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
16 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
17 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
18 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
19 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
20 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
21 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
22 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24 * This software is derived from software provide by Kwikbyte who specifically
25 * disclaimed copyright on the code.
30 /******************************************************************************
34 * Instantiation of routines for MAC/ethernet functions supporting tftp.
36 * Revision information:
38 * 28AUG2004 kb_admin initial creation
39 * 08JAN2005 kb_admin added tftp download
40 * also adapted from external sources
43 * No warranty, expressed or implied, is included with this software. It is
44 * provided "AS IS" and no warranty of any kind including statutory or aspects
45 * relating to merchantability or fitness for any purpose is provided. All
46 * intellectual property rights of others is maintained with the respective
47 * owners. This software is not copyrighted and is intended for reference
50 ******************************************************************************/
52 #include "at91rm9200.h"
53 #include "at91rm9200_lowlevel.h"
57 /* ****************************** GLOBALS *************************************/
60 unsigned localMACSet, serverMACSet;
61 unsigned char localMACAddr[6];
62 unsigned localMAClow, localMAChigh;
63 unsigned localIPSet, serverIPSet;
64 unsigned short serverPort, localPort;
65 receive_descriptor_t *p_rxBD;
67 /* ********************** PRIVATE FUNCTIONS/DATA ******************************/
70 * .KB_C_FN_DEFINITION_START
71 * void EMAC_SetMACAddress(unsigned low_address, unsigned high_address)
72 * This global function sets the MAC address. low_address is the first
73 * four bytes while high_address is the last 2 bytes of the 48-bit value.
74 * .KB_C_FN_DEFINITION_END
77 EMAC_SetMACAddress(unsigned char mac[6])
79 AT91PS_PMC pPMC = AT91C_BASE_PMC;
80 AT91PS_EMAC pEmac = AT91C_BASE_EMAC;
82 /* enable the peripheral clock before using EMAC */
83 pPMC->PMC_PCER = ((unsigned) 1 << AT91C_ID_EMAC);
85 p_memcpy(localMACAddr, mac, 6);
86 localMAClow = (mac[2] << 24) | (mac[3] << 16) | (mac[4] << 8) | mac[5];
87 localMAChigh = (mac[0] << 8) | mac[1];
90 AT91C_BASE_PMC->PMC_PCER = 1u << AT91C_ID_EMAC;
91 AT91C_BASE_PIOA->PIO_ASR =
92 AT91C_PA14_ERXER | AT91C_PA12_ERX0 | AT91C_PA13_ERX1 |
93 AT91C_PA8_ETXEN | AT91C_PA16_EMDIO | AT91C_PA9_ETX0 |
94 AT91C_PA10_ETX1 | AT91C_PA11_ECRS_ECRSDV | AT91C_PA15_EMDC |
95 AT91C_PA7_ETXCK_EREFCK;
96 AT91C_BASE_PIOA->PIO_PDR =
97 AT91C_PA14_ERXER | AT91C_PA12_ERX0 | AT91C_PA13_ERX1 |
98 AT91C_PA8_ETXEN | AT91C_PA16_EMDIO | AT91C_PA9_ETX0 |
99 AT91C_PA10_ETX1 | AT91C_PA11_ECRS_ECRSDV | AT91C_PA15_EMDC |
100 AT91C_PA7_ETXCK_EREFCK;
101 #ifdef BOOT_KB9202 /* Really !RMII */
102 AT91C_BASE_PIOB->PIO_BSR =
103 AT91C_PB12_ETX2 | AT91C_PB13_ETX3 | AT91C_PB14_ETXER |
104 AT91C_PB15_ERX2 | AT91C_PB16_ERX3 | AT91C_PB17_ERXDV |
105 AT91C_PB18_ECOL | AT91C_PB19_ERXCK;
106 AT91C_BASE_PIOB->PIO_PDR =
107 AT91C_PB12_ETX2 | AT91C_PB13_ETX3 | AT91C_PB14_ETXER |
108 AT91C_PB15_ERX2 | AT91C_PB16_ERX3 | AT91C_PB17_ERXDV |
109 AT91C_PB18_ECOL | AT91C_PB19_ERXCK;
113 pEmac->EMAC_CFG = (pEmac->EMAC_CFG & ~(AT91C_EMAC_CLK)) |
117 AT91C_EMAC_CLK_HCLK_32 | AT91C_EMAC_CAF;
118 // the sequence write EMAC_SA1L and write EMAC_SA1H must be respected
119 pEmac->EMAC_SA1L = localMAClow;
120 pEmac->EMAC_SA1H = localMAChigh;
124 * .KB_C_FN_DEFINITION_START
125 * void EMAC_Init(void)
126 * This global function initializes variables used in tftp transfers.
127 * .KB_C_FN_DEFINITION_END
132 p_rxBD = (receive_descriptor_t*)RX_BUFFER_START;
137 localPort = SWAP16(0x8002);