mirror of
https://github.com/Fishwaldo/u-boot.git
synced 2025-03-21 06:31:31 +00:00
KS8695: convert KS8695 eth driver to CONFIG_MULTI_ETH
Trivial conversion of the ks8695eth driver to a CONFIG_MULTI_ETH type driver. Signed-off-by: Greg Ungerer <greg.ungerer@opengear.com>
This commit is contained in:
parent
a00e749d5b
commit
1e8ff7145c
6 changed files with 39 additions and 14 deletions
|
@ -74,6 +74,10 @@ int board_late_init (void)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int board_eth_init(bd_t *bis)
|
||||||
|
{
|
||||||
|
return ks8695_eth_initialize();
|
||||||
|
}
|
||||||
|
|
||||||
int board_init (void)
|
int board_init (void)
|
||||||
{
|
{
|
||||||
|
|
|
@ -74,6 +74,10 @@ int board_late_init (void)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int board_eth_init(bd_t *bis)
|
||||||
|
{
|
||||||
|
return ks8695_eth_initialize();
|
||||||
|
}
|
||||||
|
|
||||||
int board_init (void)
|
int board_init (void)
|
||||||
{
|
{
|
||||||
|
|
|
@ -99,7 +99,7 @@ void ks8695_getmac(void)
|
||||||
|
|
||||||
/****************************************************************************/
|
/****************************************************************************/
|
||||||
|
|
||||||
void eth_reset(bd_t *bd)
|
static int ks8695_eth_init(struct eth_device *dev, bd_t *bd)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
@ -151,21 +151,12 @@ void eth_reset(bd_t *bd)
|
||||||
ks8695_write(KS8695_LAN_DMA_RX_START, 0x1);
|
ks8695_write(KS8695_LAN_DMA_RX_START, 0x1);
|
||||||
|
|
||||||
printf("KS8695 ETHERNET: %pM\n", eth_mac);
|
printf("KS8695 ETHERNET: %pM\n", eth_mac);
|
||||||
}
|
|
||||||
|
|
||||||
/****************************************************************************/
|
|
||||||
|
|
||||||
int eth_init(bd_t *bd)
|
|
||||||
{
|
|
||||||
debug ("%s(%d): eth_init()\n", __FILE__, __LINE__);
|
|
||||||
|
|
||||||
eth_reset(bd);
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************/
|
/****************************************************************************/
|
||||||
|
|
||||||
void eth_halt(void)
|
static void ks8695_eth_halt(struct eth_device *dev)
|
||||||
{
|
{
|
||||||
debug ("%s(%d): eth_halt()\n", __FILE__, __LINE__);
|
debug ("%s(%d): eth_halt()\n", __FILE__, __LINE__);
|
||||||
|
|
||||||
|
@ -176,7 +167,7 @@ void eth_halt(void)
|
||||||
|
|
||||||
/****************************************************************************/
|
/****************************************************************************/
|
||||||
|
|
||||||
int eth_rx(void)
|
static int ks8695_eth_recv(struct eth_device *dev)
|
||||||
{
|
{
|
||||||
volatile struct ks8695_rxdesc *dp;
|
volatile struct ks8695_rxdesc *dp;
|
||||||
int i, len = 0;
|
int i, len = 0;
|
||||||
|
@ -199,7 +190,8 @@ int eth_rx(void)
|
||||||
|
|
||||||
/****************************************************************************/
|
/****************************************************************************/
|
||||||
|
|
||||||
int eth_send(volatile void *packet, int len)
|
static int ks8695_eth_send(struct eth_device *dev, volatile void *packet,
|
||||||
|
int len)
|
||||||
{
|
{
|
||||||
volatile struct ks8695_txdesc *dp;
|
volatile struct ks8695_txdesc *dp;
|
||||||
static int next = 0;
|
static int next = 0;
|
||||||
|
@ -224,5 +216,27 @@ int eth_send(volatile void *packet, int len)
|
||||||
if (++next >= TXDESCS)
|
if (++next >= TXDESCS)
|
||||||
next = 0;
|
next = 0;
|
||||||
|
|
||||||
return len;
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************/
|
||||||
|
|
||||||
|
int ks8695_eth_initialize(void)
|
||||||
|
{
|
||||||
|
struct eth_device *dev;
|
||||||
|
|
||||||
|
dev = malloc(sizeof(*dev));
|
||||||
|
if (dev == NULL)
|
||||||
|
return -1;
|
||||||
|
memset(dev, 0, sizeof(*dev));
|
||||||
|
|
||||||
|
dev->iobase = KS8695_IO_BASE + KS8695_LAN_DMA_TX;
|
||||||
|
dev->init = ks8695_eth_init;
|
||||||
|
dev->halt = ks8695_eth_halt;
|
||||||
|
dev->send = ks8695_eth_send;
|
||||||
|
dev->recv = ks8695_eth_recv;
|
||||||
|
strcpy(dev->name, "ks8695eth");
|
||||||
|
|
||||||
|
eth_register(dev);
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,6 +38,7 @@
|
||||||
#define CONFIG_INITRD_TAG 1
|
#define CONFIG_INITRD_TAG 1
|
||||||
|
|
||||||
#define CONFIG_DRIVER_KS8695ETH /* use KS8695 ethernet driver */
|
#define CONFIG_DRIVER_KS8695ETH /* use KS8695 ethernet driver */
|
||||||
|
#define CONFIG_NET_MULTI
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Size of malloc() pool
|
* Size of malloc() pool
|
||||||
|
|
|
@ -38,6 +38,7 @@
|
||||||
#define CONFIG_INITRD_TAG 1
|
#define CONFIG_INITRD_TAG 1
|
||||||
|
|
||||||
#define CONFIG_DRIVER_KS8695ETH /* use KS8695 ethernet driver */
|
#define CONFIG_DRIVER_KS8695ETH /* use KS8695 ethernet driver */
|
||||||
|
#define CONFIG_NET_MULTI
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Size of malloc() pool
|
* Size of malloc() pool
|
||||||
|
|
|
@ -66,6 +66,7 @@ int ftmac100_initialize(bd_t *bits);
|
||||||
int greth_initialize(bd_t *bis);
|
int greth_initialize(bd_t *bis);
|
||||||
void gt6426x_eth_initialize(bd_t *bis);
|
void gt6426x_eth_initialize(bd_t *bis);
|
||||||
int inca_switch_initialize(bd_t *bis);
|
int inca_switch_initialize(bd_t *bis);
|
||||||
|
int ks8695_eth_initialize(bd_t *bis);
|
||||||
int lan91c96_initialize(u8 dev_num, int base_addr);
|
int lan91c96_initialize(u8 dev_num, int base_addr);
|
||||||
int macb_eth_initialize(int id, void *regs, unsigned int phy_addr);
|
int macb_eth_initialize(int id, void *regs, unsigned int phy_addr);
|
||||||
int mcdmafec_initialize(bd_t *bis);
|
int mcdmafec_initialize(bd_t *bis);
|
||||||
|
|
Loading…
Add table
Reference in a new issue