2002-11-03 00:24:07 +00:00
|
|
|
/*
|
2004-01-02 14:00:00 +00:00
|
|
|
* (C) Copyright 2001-2004
|
2002-11-03 00:24:07 +00:00
|
|
|
* Wolfgang Denk, DENX Software Engineering, wd@denx.de.
|
|
|
|
*
|
|
|
|
* 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
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <common.h>
|
|
|
|
#include <command.h>
|
2007-07-05 16:01:24 +00:00
|
|
|
#include <driver.h>
|
|
|
|
#include <init.h>
|
2002-11-03 00:24:07 +00:00
|
|
|
#include <net.h>
|
2005-11-30 17:06:04 +00:00
|
|
|
#include <miiphy.h>
|
2007-07-05 16:01:25 +00:00
|
|
|
#include <malloc.h>
|
|
|
|
|
|
|
|
typedef enum eth_cookies {
|
|
|
|
PARAM_IP,
|
|
|
|
PARAM_MAC,
|
|
|
|
PARAM_GW,
|
|
|
|
PARAM_NM,
|
|
|
|
} eth_cookies_t;
|
|
|
|
|
|
|
|
static char *eth_get(struct device_d* dev, ulong cookie)
|
|
|
|
{
|
|
|
|
struct eth_device *ndev = dev->driver->type_data;
|
|
|
|
|
|
|
|
if (cookie >= 4)
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
return ndev->param[cookie];
|
|
|
|
}
|
|
|
|
|
|
|
|
static int eth_set(struct device_d* dev, ulong cookie, char *newval)
|
|
|
|
{
|
|
|
|
struct eth_device *ndev = dev->driver->type_data;
|
|
|
|
char **val = &ndev->param[cookie];
|
|
|
|
|
|
|
|
if (*val)
|
|
|
|
free(*val);
|
|
|
|
|
|
|
|
*val = newval;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static struct param_d eth_params[] = {
|
|
|
|
{ .name = "ip", .cookie = PARAM_IP, .set = eth_set, .get = eth_get},
|
|
|
|
{ .name = "mac", .cookie = PARAM_MAC, .set = eth_set, .get = eth_get},
|
|
|
|
{ .name = "gateway", .cookie = PARAM_GW, .set = eth_set, .get = eth_get},
|
|
|
|
{ .name = "netmask", .cookie = PARAM_NM, .set = eth_set, .get = eth_get},
|
|
|
|
};
|
2002-11-03 00:24:07 +00:00
|
|
|
|
2007-07-05 16:01:22 +00:00
|
|
|
static struct eth_device *eth_current;
|
|
|
|
|
|
|
|
void eth_set_current(struct eth_device *eth)
|
|
|
|
{
|
|
|
|
eth_current = eth;
|
|
|
|
}
|
|
|
|
|
|
|
|
struct eth_device * eth_get_current(void)
|
|
|
|
{
|
|
|
|
return eth_current;
|
|
|
|
}
|
|
|
|
|
2007-07-05 16:01:24 +00:00
|
|
|
int eth_init(void)
|
2007-07-05 16:01:22 +00:00
|
|
|
{
|
|
|
|
|
|
|
|
if (!eth_current)
|
|
|
|
return 0;
|
|
|
|
|
2007-07-05 16:01:24 +00:00
|
|
|
eth_current->open(eth_current);
|
2007-07-05 16:01:22 +00:00
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
void eth_halt(void)
|
|
|
|
{
|
|
|
|
if (!eth_current)
|
|
|
|
return;
|
|
|
|
|
|
|
|
eth_current->halt(eth_current);
|
|
|
|
|
|
|
|
eth_current->state = ETH_STATE_PASSIVE;
|
|
|
|
}
|
|
|
|
|
|
|
|
int eth_send(volatile void *packet, int length)
|
|
|
|
{
|
|
|
|
if (!eth_current)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
return eth_current->send(eth_current, packet, length);
|
|
|
|
}
|
|
|
|
|
|
|
|
int eth_rx(void)
|
|
|
|
{
|
|
|
|
if (!eth_current)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
return eth_current->recv(eth_current);
|
|
|
|
}
|
|
|
|
|
2007-07-05 16:01:24 +00:00
|
|
|
static int eth_handle(struct device_d *dev)
|
2005-10-28 20:30:33 +00:00
|
|
|
{
|
2007-07-05 16:01:22 +00:00
|
|
|
unsigned char ethaddr_tmp[20];
|
2007-07-05 16:01:23 +00:00
|
|
|
unsigned char *ethaddr;
|
2007-07-05 16:01:24 +00:00
|
|
|
struct eth_device *ndev = dev->driver->type_data;
|
2007-07-05 16:01:23 +00:00
|
|
|
char *e = NULL;
|
2007-07-05 16:01:22 +00:00
|
|
|
int i;
|
|
|
|
|
2007-07-05 16:01:24 +00:00
|
|
|
if (!ndev->get_mac_address) {
|
2007-07-05 16:01:22 +00:00
|
|
|
printf("no get_mac_address found for current eth device\n");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2007-07-05 16:01:25 +00:00
|
|
|
for (i = 0; i < 4; i++)
|
|
|
|
dev_add_parameter(dev, ð_params[i]);
|
|
|
|
|
2007-07-05 16:01:24 +00:00
|
|
|
ethaddr = ndev->enetaddr;
|
2007-07-05 16:01:22 +00:00
|
|
|
|
|
|
|
/* Try to get a MAC address from the eeprom set 'ethaddr' to it.
|
|
|
|
* If this fails we rely on 'ethaddr' being set by the user.
|
|
|
|
*/
|
2007-07-05 16:01:24 +00:00
|
|
|
if (ndev->get_mac_address(ndev, ethaddr) == 0) {
|
2007-07-05 16:01:22 +00:00
|
|
|
sprintf (ethaddr_tmp, "%02X:%02X:%02X:%02X:%02X:%02X",
|
|
|
|
ethaddr[0], ethaddr[1], ethaddr[2], ethaddr[3], ethaddr[4], ethaddr[5]);
|
|
|
|
printf("got MAC address from EEPROM: %s\n",ethaddr_tmp);
|
|
|
|
setenv ("ethaddr", ethaddr_tmp);
|
|
|
|
} else {
|
|
|
|
ethaddr = getenv ("ethaddr");
|
|
|
|
if (!ethaddr){
|
|
|
|
printf("could not get MAC address from device and ethaddr not set\n");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2007-07-05 16:01:23 +00:00
|
|
|
printf("got MAC address from Environment: %s\n",ethaddr);
|
2007-07-05 16:01:22 +00:00
|
|
|
for(i = 0; i < 6; i++) {
|
2007-07-05 16:01:24 +00:00
|
|
|
ndev->enetaddr[i] = ethaddr ? simple_strtoul (ethaddr, &e, 16) : 0;
|
2007-07-05 16:01:22 +00:00
|
|
|
if (ethaddr) {
|
|
|
|
ethaddr = (*e) ? e + 1 : e;
|
|
|
|
}
|
2007-07-05 16:01:24 +00:00
|
|
|
ndev->set_mac_address(eth_current, ndev->enetaddr);
|
2007-07-05 16:01:22 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-07-05 16:01:24 +00:00
|
|
|
eth_current = ndev;
|
2005-10-28 20:30:33 +00:00
|
|
|
return 0;
|
|
|
|
}
|
2007-07-05 16:01:24 +00:00
|
|
|
|
|
|
|
int eth_initialize(void)
|
|
|
|
{
|
|
|
|
register_device_type_handler(ð_handle, DEVICE_TYPE_ETHER);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
core_initcall(eth_initialize);
|