提交 14abfe36 编写于 作者: W Wolfgang Denk

Merge branch 'master' of /home/wd/git/u-boot/custodians

This patch rewrites the miiphybb ( Bit-banged MII bus driver ) in order to
support an arbitrary number of mii buses. This feature is useful when your
board uses different mii buses for different phys and all (or a part) of these
buses are implemented via bit-banging mode.
The driver requires that the following macros should be defined into the board
configuration file:
CONFIG_BITBANGMII - Enable the miiphybb driver
CONFIG_BITBANGMII_MULTI - Enable the multi bus support
If the CONFIG_BITBANGMII_MULTI is not defined, the board's config file needs
to define at least the following macros:
MII_INIT - Generic code to enable the MII bus (optional)
MDIO_DECLARE - Declaration needed to access to the MDIO pin (optional)
MDIO_ACTIVE - Activate the MDIO pin as out pin
MDIO_TRISTATE - Activate the MDIO pin as input/tristate pin
MDIO_READ - Read the MDIO pin
MDIO(v) - Write v on the MDIO pin
MDC_DECLARE - Declaration needed to access to the MDC pin (optional)
MDC(v) - Write v on the MDC pin
The previous macros make the driver compatible with the previous version
(that didn't support the multi-bus).
When the CONFIG_BITBANGMII_MULTI is also defined, the board code needs to fill
the bb_miiphy_buses[] array with a record for each required bus and declare
the bb_miiphy_buses_num variable with the number of mii buses.
The record (struct bb_miiphy_bus) has the following fields/callbacks (see
miiphy.h for details):
char name[] - The symbolic name that must be equal to the MII bus
registered name
int (*init)() - Initialization function called at startup time (just
before the Ethernet initialization)
int (*mdio_active)() - Activate the MDIO pin as output
int (*mdio_tristate)() - Activate the MDIO pin as input/tristate pin
int (*set_mdio)() - Write the MDIO pin
int (*get_mdio)() - Read the MDIO pin
int (*set_mdc)() - Write the MDC pin
int (*delay)() - Delay function
void *priv - Private data used by board specific code
The board code will look like:
struct bb_miiphy_bus bb_miiphy_buses[] = {
{ .name = "miibus#1", .init = b1_init, .mdio_active = b1_mdio_active, ... },
{ .name = "miibus#2", .init = b2_init, .mdio_active = b2_mdio_active, ... },
...
};
int bb_miiphy_buses_num = sizeof(bb_miiphy_buses) /
sizeof(bb_miiphy_buses[0]);
2009 Industrie Dial Face S.p.A.
Luigi 'Comio' Mantellini <luigi.mantellini@idf-hit.com>
/* /*
* (C) Copyright 2009 Industrie Dial Face S.p.A.
* Luigi 'Comio' Mantellini <luigi.mantellini@idf-hit.com>
*
* (C) Copyright 2001 * (C) Copyright 2001
* Gerald Van Baren, Custom IDEAS, vanbaren@cideas.com. * Gerald Van Baren, Custom IDEAS, vanbaren@cideas.com.
* *
...@@ -29,18 +32,144 @@ ...@@ -29,18 +32,144 @@
#include <common.h> #include <common.h>
#include <ioports.h> #include <ioports.h>
#include <ppc_asm.tmpl> #include <ppc_asm.tmpl>
#include <miiphy.h>
#define BB_MII_RELOCATE(v,off) (v += (v?off:0))
DECLARE_GLOBAL_DATA_PTR;
#ifndef CONFIG_BITBANGMII_MULTI
/*
* If CONFIG_BITBANGMII_MULTI is not defined we use a
* compatibility layer with the previous miiphybb implementation
* based on macros usage.
*
*/
static int bb_mii_init_wrap(struct bb_miiphy_bus *bus)
{
#ifdef MII_INIT
MII_INIT;
#endif
return 0;
}
static int bb_mdio_active_wrap(struct bb_miiphy_bus *bus)
{
#ifdef MDIO_DECLARE
MDIO_DECLARE;
#endif
MDIO_ACTIVE;
return 0;
}
static int bb_mdio_tristate_wrap(struct bb_miiphy_bus *bus)
{
#ifdef MDIO_DECLARE
MDIO_DECLARE;
#endif
MDIO_TRISTATE;
return 0;
}
static int bb_set_mdio_wrap(struct bb_miiphy_bus *bus, int v)
{
#ifdef MDIO_DECLARE
MDIO_DECLARE;
#endif
MDIO(v);
return 0;
}
static int bb_get_mdio_wrap(struct bb_miiphy_bus *bus, int *v)
{
#ifdef MDIO_DECLARE
MDIO_DECLARE;
#endif
*v = MDIO_READ;
return 0;
}
static int bb_set_mdc_wrap(struct bb_miiphy_bus *bus, int v)
{
#ifdef MDC_DECLARE
MDC_DECLARE;
#endif
MDC(v);
return 0;
}
static int bb_delay_wrap(struct bb_miiphy_bus *bus)
{
MIIDELAY;
return 0;
}
struct bb_miiphy_bus bb_miiphy_buses[] = {
{
.name = BB_MII_DEVNAME,
.init = bb_mii_init_wrap,
.mdio_active = bb_mdio_active_wrap,
.mdio_tristate = bb_mdio_tristate_wrap,
.set_mdio = bb_set_mdio_wrap,
.get_mdio = bb_get_mdio_wrap,
.set_mdc = bb_set_mdc_wrap,
.delay = bb_delay_wrap,
}
};
int bb_miiphy_buses_num = sizeof(bb_miiphy_buses) /
sizeof(bb_miiphy_buses[0]);
#endif
void bb_miiphy_init(void)
{
int i;
for (i = 0; i < bb_miiphy_buses_num; i++) {
#if !defined(CONFIG_RELOC_FIXUP_WORKS)
/* Relocate the hook pointers*/
BB_MII_RELOCATE(bb_miiphy_buses[i].init, gd->reloc_off);
BB_MII_RELOCATE(bb_miiphy_buses[i].mdio_active, gd->reloc_off);
BB_MII_RELOCATE(bb_miiphy_buses[i].mdio_tristate, gd->reloc_off);
BB_MII_RELOCATE(bb_miiphy_buses[i].set_mdio, gd->reloc_off);
BB_MII_RELOCATE(bb_miiphy_buses[i].get_mdio, gd->reloc_off);
BB_MII_RELOCATE(bb_miiphy_buses[i].set_mdc, gd->reloc_off);
BB_MII_RELOCATE(bb_miiphy_buses[i].delay, gd->reloc_off);
#endif
if (bb_miiphy_buses[i].init != NULL) {
bb_miiphy_buses[i].init(&bb_miiphy_buses[i]);
}
}
}
static inline struct bb_miiphy_bus *bb_miiphy_getbus(char *devname)
{
#ifdef CONFIG_BITBANGMII_MULTI
int i;
/* Search the correct bus */
for (i = 0; i < bb_miiphy_buses_num; i++) {
if (!strcmp(bb_miiphy_buses[i].name, devname)) {
return &bb_miiphy_buses[i];
}
}
return NULL;
#else
/* We have just one bitbanging bus */
return &bb_miiphy_buses[0];
#endif
}
/***************************************************************************** /*****************************************************************************
* *
* Utility to send the preamble, address, and register (common to read * Utility to send the preamble, address, and register (common to read
* and write). * and write).
*/ */
static void miiphy_pre (char read, unsigned char addr, unsigned char reg) static void miiphy_pre(struct bb_miiphy_bus *bus, char read,
unsigned char addr, unsigned char reg)
{ {
int j; /* counter */ int j;
#if !(defined(CONFIG_EP8248) || defined(CONFIG_EP82XXM))
volatile ioport_t *iop = ioport_addr ((immap_t *) CONFIG_SYS_IMMR, MDIO_PORT);
#endif
/* /*
* Send a 32 bit preamble ('1's) with an extra '1' bit for good measure. * Send a 32 bit preamble ('1's) with an extra '1' bit for good measure.
...@@ -50,67 +179,66 @@ static void miiphy_pre (char read, unsigned char addr, unsigned char reg) ...@@ -50,67 +179,66 @@ static void miiphy_pre (char read, unsigned char addr, unsigned char reg)
* but it is safer and will be much more robust. * but it is safer and will be much more robust.
*/ */
MDIO_ACTIVE; bus->mdio_active(bus);
MDIO (1); bus->set_mdio(bus, 1);
for (j = 0; j < 32; j++) { for (j = 0; j < 32; j++) {
MDC (0); bus->set_mdc(bus, 0);
MIIDELAY; bus->delay(bus);
MDC (1); bus->set_mdc(bus, 1);
MIIDELAY; bus->delay(bus);
} }
/* send the start bit (01) and the read opcode (10) or write (10) */ /* send the start bit (01) and the read opcode (10) or write (10) */
MDC (0); bus->set_mdc(bus, 0);
MDIO (0); bus->set_mdio(bus, 0);
MIIDELAY; bus->delay(bus);
MDC (1); bus->set_mdc(bus, 1);
MIIDELAY; bus->delay(bus);
MDC (0); bus->set_mdc(bus, 0);
MDIO (1); bus->set_mdio(bus, 1);
MIIDELAY; bus->delay(bus);
MDC (1); bus->set_mdc(bus, 1);
MIIDELAY; bus->delay(bus);
MDC (0); bus->set_mdc(bus, 0);
MDIO (read); bus->set_mdio(bus, read);
MIIDELAY; bus->delay(bus);
MDC (1); bus->set_mdc(bus, 1);
MIIDELAY; bus->delay(bus);
MDC (0); bus->set_mdc(bus, 0);
MDIO (!read); bus->set_mdio(bus, !read);
MIIDELAY; bus->delay(bus);
MDC (1); bus->set_mdc(bus, 1);
MIIDELAY; bus->delay(bus);
/* send the PHY address */ /* send the PHY address */
for (j = 0; j < 5; j++) { for (j = 0; j < 5; j++) {
MDC (0); bus->set_mdc(bus, 0);
if ((addr & 0x10) == 0) { if ((addr & 0x10) == 0) {
MDIO (0); bus->set_mdio(bus, 0);
} else { } else {
MDIO (1); bus->set_mdio(bus, 1);
} }
MIIDELAY; bus->delay(bus);
MDC (1); bus->set_mdc(bus, 1);
MIIDELAY; bus->delay(bus);
addr <<= 1; addr <<= 1;
} }
/* send the register address */ /* send the register address */
for (j = 0; j < 5; j++) { for (j = 0; j < 5; j++) {
MDC (0); bus->set_mdc(bus, 0);
if ((reg & 0x10) == 0) { if ((reg & 0x10) == 0) {
MDIO (0); bus->set_mdio(bus, 0);
} else { } else {
MDIO (1); bus->set_mdio(bus, 1);
} }
MIIDELAY; bus->delay(bus);
MDC (1); bus->set_mdc(bus, 1);
MIIDELAY; bus->delay(bus);
reg <<= 1; reg <<= 1;
} }
} }
/***************************************************************************** /*****************************************************************************
* *
* Read a MII PHY register. * Read a MII PHY register.
...@@ -118,63 +246,69 @@ static void miiphy_pre (char read, unsigned char addr, unsigned char reg) ...@@ -118,63 +246,69 @@ static void miiphy_pre (char read, unsigned char addr, unsigned char reg)
* Returns: * Returns:
* 0 on success * 0 on success
*/ */
int bb_miiphy_read (char *devname, unsigned char addr, int bb_miiphy_read(char *devname, unsigned char addr,
unsigned char reg, unsigned short *value) unsigned char reg, unsigned short *value)
{ {
short rdreg; /* register working value */ short rdreg; /* register working value */
int j; /* counter */ int v;
#if !(defined(CONFIG_EP8248) || defined(CONFIG_EP82XXM)) int j; /* counter */
volatile ioport_t *iop = ioport_addr ((immap_t *) CONFIG_SYS_IMMR, MDIO_PORT); struct bb_miiphy_bus *bus;
#endif
bus = bb_miiphy_getbus(devname);
if (bus == NULL) {
return -1;
}
if (value == NULL) { if (value == NULL) {
puts("NULL value pointer\n"); puts("NULL value pointer\n");
return (-1); return -1;
} }
miiphy_pre (1, addr, reg); miiphy_pre (bus, 1, addr, reg);
/* tri-state our MDIO I/O pin so we can read */ /* tri-state our MDIO I/O pin so we can read */
MDC (0); bus->set_mdc(bus, 0);
MDIO_TRISTATE; bus->mdio_tristate(bus);
MIIDELAY; bus->delay(bus);
MDC (1); bus->set_mdc(bus, 1);
MIIDELAY; bus->delay(bus);
/* check the turnaround bit: the PHY should be driving it to zero */ /* check the turnaround bit: the PHY should be driving it to zero */
if (MDIO_READ != 0) { bus->get_mdio(bus, &v);
if (v != 0) {
/* puts ("PHY didn't drive TA low\n"); */ /* puts ("PHY didn't drive TA low\n"); */
for (j = 0; j < 32; j++) { for (j = 0; j < 32; j++) {
MDC (0); bus->set_mdc(bus, 0);
MIIDELAY; bus->delay(bus);
MDC (1); bus->set_mdc(bus, 1);
MIIDELAY; bus->delay(bus);
} }
/* There is no PHY, set value to 0xFFFF and return */ /* There is no PHY, set value to 0xFFFF and return */
*value = 0xFFFF; *value = 0xFFFF;
return (-1); return -1;
} }
MDC (0); bus->set_mdc(bus, 0);
MIIDELAY; bus->delay(bus);
/* read 16 bits of register data, MSB first */ /* read 16 bits of register data, MSB first */
rdreg = 0; rdreg = 0;
for (j = 0; j < 16; j++) { for (j = 0; j < 16; j++) {
MDC (1); bus->set_mdc(bus, 1);
MIIDELAY; bus->delay(bus);
rdreg <<= 1; rdreg <<= 1;
rdreg |= MDIO_READ; bus->get_mdio(bus, &v);
MDC (0); rdreg |= (v & 0x1);
MIIDELAY; bus->set_mdc(bus, 0);
bus->delay(bus);
} }
MDC (1); bus->set_mdc(bus, 1);
MIIDELAY; bus->delay(bus);
MDC (0); bus->set_mdc(bus, 0);
MIIDELAY; bus->delay(bus);
MDC (1); bus->set_mdc(bus, 1);
MIIDELAY; bus->delay(bus);
*value = rdreg; *value = rdreg;
...@@ -194,49 +328,53 @@ int bb_miiphy_read (char *devname, unsigned char addr, ...@@ -194,49 +328,53 @@ int bb_miiphy_read (char *devname, unsigned char addr,
* 0 on success * 0 on success
*/ */
int bb_miiphy_write (char *devname, unsigned char addr, int bb_miiphy_write (char *devname, unsigned char addr,
unsigned char reg, unsigned short value) unsigned char reg, unsigned short value)
{ {
struct bb_miiphy_bus *bus;
int j; /* counter */ int j; /* counter */
#if !(defined(CONFIG_EP8248) || defined(CONFIG_EP82XXM))
volatile ioport_t *iop = ioport_addr ((immap_t *) CONFIG_SYS_IMMR, MDIO_PORT);
#endif
miiphy_pre (0, addr, reg); bus = bb_miiphy_getbus(devname);
if (bus == NULL) {
/* Bus not found! */
return -1;
}
miiphy_pre (bus, 0, addr, reg);
/* send the turnaround (10) */ /* send the turnaround (10) */
MDC (0); bus->set_mdc(bus, 0);
MDIO (1); bus->set_mdio(bus, 1);
MIIDELAY; bus->delay(bus);
MDC (1); bus->set_mdc(bus, 1);
MIIDELAY; bus->delay(bus);
MDC (0); bus->set_mdc(bus, 0);
MDIO (0); bus->set_mdio(bus, 0);
MIIDELAY; bus->delay(bus);
MDC (1); bus->set_mdc(bus, 1);
MIIDELAY; bus->delay(bus);
/* write 16 bits of register data, MSB first */ /* write 16 bits of register data, MSB first */
for (j = 0; j < 16; j++) { for (j = 0; j < 16; j++) {
MDC (0); bus->set_mdc(bus, 0);
if ((value & 0x00008000) == 0) { if ((value & 0x00008000) == 0) {
MDIO (0); bus->set_mdio(bus, 0);
} else { } else {
MDIO (1); bus->set_mdio(bus, 1);
} }
MIIDELAY; bus->delay(bus);
MDC (1); bus->set_mdc(bus, 1);
MIIDELAY; bus->delay(bus);
value <<= 1; value <<= 1;
} }
/* /*
* Tri-state the MDIO line. * Tri-state the MDIO line.
*/ */
MDIO_TRISTATE; bus->mdio_tristate(bus);
MDC (0); bus->set_mdc(bus, 0);
MIIDELAY; bus->delay(bus);
MDC (1); bus->set_mdc(bus, 1);
MIIDELAY; bus->delay(bus);
return 0; return 0;
} }
\ No newline at end of file
...@@ -84,6 +84,10 @@ ...@@ -84,6 +84,10 @@
* GPIO pins used for bit-banged MII communications * GPIO pins used for bit-banged MII communications
*/ */
#define MDIO_PORT 3 /* Port D */ #define MDIO_PORT 3 /* Port D */
#define MDIO_DECLARE volatile ioport_t *iop = ioport_addr ( \
(immap_t *) CONFIG_SYS_IMMR, MDIO_PORT )
#define MDC_DECLARE MDIO_DECLARE
#define CONFIG_SYS_MDIO_PIN 0x00040000 /* PD13 */ #define CONFIG_SYS_MDIO_PIN 0x00040000 /* PD13 */
#define CONFIG_SYS_MDC_PIN 0x00080000 /* PD12 */ #define CONFIG_SYS_MDC_PIN 0x00080000 /* PD12 */
......
...@@ -150,6 +150,9 @@ ...@@ -150,6 +150,9 @@
* GPIO pins used for bit-banged MII communications * GPIO pins used for bit-banged MII communications
*/ */
#define MDIO_PORT 2 /* Port C */ #define MDIO_PORT 2 /* Port C */
#define MDIO_DECLARE volatile ioport_t *iop = ioport_addr ( \
(immap_t *) CONFIG_SYS_IMMR, MDIO_PORT )
#define MDC_DECLARE MDIO_DECLARE
#if CONFIG_ADSTYPE == CONFIG_SYS_8272ADS #if CONFIG_ADSTYPE == CONFIG_SYS_8272ADS
#define CONFIG_SYS_MDIO_PIN 0x00002000 /* PC18 */ #define CONFIG_SYS_MDIO_PIN 0x00002000 /* PC18 */
......
...@@ -96,6 +96,10 @@ ...@@ -96,6 +96,10 @@
* Port pins used for bit-banged MII communictions (if applicable). * Port pins used for bit-banged MII communictions (if applicable).
*/ */
#define MDIO_PORT 2 /* Port C */ #define MDIO_PORT 2 /* Port C */
#define MDIO_DECLARE volatile ioport_t *iop = ioport_addr ( \
(immap_t *) CONFIG_SYS_IMMR, MDIO_PORT )
#define MDC_DECLARE MDIO_DECLARE
#define MDIO_ACTIVE (iop->pdir |= 0x00400000) #define MDIO_ACTIVE (iop->pdir |= 0x00400000)
#define MDIO_TRISTATE (iop->pdir &= ~0x00400000) #define MDIO_TRISTATE (iop->pdir &= ~0x00400000)
#define MDIO_READ ((iop->pdat & 0x00400000) != 0) #define MDIO_READ ((iop->pdat & 0x00400000) != 0)
......
...@@ -363,6 +363,10 @@ ...@@ -363,6 +363,10 @@
* GPIO pins used for bit-banged MII communications * GPIO pins used for bit-banged MII communications
*/ */
#define MDIO_PORT 2 /* Port C */ #define MDIO_PORT 2 /* Port C */
#define MDIO_DECLARE volatile ioport_t *iop = ioport_addr ( \
(immap_t *) CONFIG_SYS_IMMR, MDIO_PORT )
#define MDC_DECLARE MDIO_DECLARE
#define MDIO_ACTIVE (iop->pdir |= 0x00400000) #define MDIO_ACTIVE (iop->pdir |= 0x00400000)
#define MDIO_TRISTATE (iop->pdir &= ~0x00400000) #define MDIO_TRISTATE (iop->pdir &= ~0x00400000)
#define MDIO_READ ((iop->pdat & 0x00400000) != 0) #define MDIO_READ ((iop->pdat & 0x00400000) != 0)
......
...@@ -103,6 +103,10 @@ ...@@ -103,6 +103,10 @@
* GPIO pins used for bit-banged MII communications * GPIO pins used for bit-banged MII communications
*/ */
#define MDIO_PORT 2 /* Port C */ #define MDIO_PORT 2 /* Port C */
#define MDIO_DECLARE volatile ioport_t *iop = ioport_addr ( \
(immap_t *) CONFIG_SYS_IMMR, MDIO_PORT )
#define MDC_DECLARE MDIO_DECLARE
#define MDIO_ACTIVE (iop->pdir |= 0x00400000) #define MDIO_ACTIVE (iop->pdir |= 0x00400000)
#define MDIO_TRISTATE (iop->pdir &= ~0x00400000) #define MDIO_TRISTATE (iop->pdir &= ~0x00400000)
#define MDIO_READ ((iop->pdat & 0x00400000) != 0) #define MDIO_READ ((iop->pdat & 0x00400000) != 0)
......
...@@ -290,6 +290,10 @@ ...@@ -290,6 +290,10 @@
* GPIO pins used for bit-banged MII communications * GPIO pins used for bit-banged MII communications
*/ */
#define MDIO_PORT 2 /* Port C */ #define MDIO_PORT 2 /* Port C */
#define MDIO_DECLARE volatile ioport_t *iop = ioport_addr ( \
(immap_t *) CONFIG_SYS_IMMR, MDIO_PORT )
#define MDC_DECLARE MDIO_DECLARE
#define MDIO_ACTIVE (iop->pdir |= 0x00400000) #define MDIO_ACTIVE (iop->pdir |= 0x00400000)
#define MDIO_TRISTATE (iop->pdir &= ~0x00400000) #define MDIO_TRISTATE (iop->pdir &= ~0x00400000)
#define MDIO_READ ((iop->pdat & 0x00400000) != 0) #define MDIO_READ ((iop->pdat & 0x00400000) != 0)
......
...@@ -219,6 +219,9 @@ ...@@ -219,6 +219,9 @@
* GPIO pins used for bit-banged MII communications * GPIO pins used for bit-banged MII communications
*/ */
#define MDIO_PORT 2 /* Port C */ #define MDIO_PORT 2 /* Port C */
#define MDIO_DECLARE volatile ioport_t *iop = ioport_addr ( \
(immap_t *) CONFIG_SYS_IMMR, MDIO_PORT )
#define MDC_DECLARE MDIO_DECLARE
#if STK82xx_150 #if STK82xx_150
#define CONFIG_SYS_MDIO_PIN 0x00008000 /* PC16 */ #define CONFIG_SYS_MDIO_PIN 0x00008000 /* PC16 */
......
...@@ -124,6 +124,11 @@ ...@@ -124,6 +124,11 @@
#define CONFIG_BITBANGMII #define CONFIG_BITBANGMII
#define MDIO_PORT 1 /* Port B */ #define MDIO_PORT 1 /* Port B */
#define MDIO_DECLARE volatile ioport_t *iop = ioport_addr ( \
(immap_t *) CONFIG_SYS_IMMR, MDIO_PORT )
#define MDC_DECLARE MDIO_DECLARE
#define CONFIG_SYS_MDIO_PIN 0x00002000 /* PB18 */ #define CONFIG_SYS_MDIO_PIN 0x00002000 /* PB18 */
#define CONFIG_SYS_MDC_PIN 0x00001000 /* PB19 */ #define CONFIG_SYS_MDC_PIN 0x00001000 /* PB19 */
#define MDIO_ACTIVE (iop->pdir |= CONFIG_SYS_MDIO_PIN) #define MDIO_ACTIVE (iop->pdir |= CONFIG_SYS_MDIO_PIN)
......
...@@ -86,6 +86,10 @@ ...@@ -86,6 +86,10 @@
* GPIO pins used for bit-banged MII communications * GPIO pins used for bit-banged MII communications
*/ */
#define MDIO_PORT 2 /* Port C */ #define MDIO_PORT 2 /* Port C */
#define MDIO_DECLARE volatile ioport_t *iop = ioport_addr ( \
(immap_t *) CONFIG_SYS_IMMR, MDIO_PORT )
#define MDC_DECLARE MDIO_DECLARE
#define MDIO_ACTIVE (iop->pdir |= 0x00400000) #define MDIO_ACTIVE (iop->pdir |= 0x00400000)
#define MDIO_TRISTATE (iop->pdir &= ~0x00400000) #define MDIO_TRISTATE (iop->pdir &= ~0x00400000)
#define MDIO_READ ((iop->pdat & 0x00400000) != 0) #define MDIO_READ ((iop->pdat & 0x00400000) != 0)
......
...@@ -92,6 +92,7 @@ ...@@ -92,6 +92,7 @@
* GPIO pins used for bit-banged MII communications * GPIO pins used for bit-banged MII communications
*/ */
#define MDIO_PORT 0 /* Not used - implemented in BCSR */ #define MDIO_PORT 0 /* Not used - implemented in BCSR */
#define MDIO_ACTIVE (*(vu_char *)(CONFIG_SYS_BCSR + 8) &= 0xFB) #define MDIO_ACTIVE (*(vu_char *)(CONFIG_SYS_BCSR + 8) &= 0xFB)
#define MDIO_TRISTATE (*(vu_char *)(CONFIG_SYS_BCSR + 8) |= 0x04) #define MDIO_TRISTATE (*(vu_char *)(CONFIG_SYS_BCSR + 8) |= 0x04)
#define MDIO_READ (*(vu_char *)(CONFIG_SYS_BCSR + 8) & 1) #define MDIO_READ (*(vu_char *)(CONFIG_SYS_BCSR + 8) & 1)
......
...@@ -85,6 +85,7 @@ ...@@ -85,6 +85,7 @@
* GPIO pins used for bit-banged MII communications * GPIO pins used for bit-banged MII communications
*/ */
#define MDIO_PORT 0 /* Not used - implemented in BCSR */ #define MDIO_PORT 0 /* Not used - implemented in BCSR */
#define MDIO_ACTIVE (*(vu_char *)(CONFIG_SYS_BCSR + 8) &= 0xFB) #define MDIO_ACTIVE (*(vu_char *)(CONFIG_SYS_BCSR + 8) &= 0xFB)
#define MDIO_TRISTATE (*(vu_char *)(CONFIG_SYS_BCSR + 8) |= 0x04) #define MDIO_TRISTATE (*(vu_char *)(CONFIG_SYS_BCSR + 8) |= 0x04)
#define MDIO_READ (*(vu_char *)(CONFIG_SYS_BCSR + 8) & 1) #define MDIO_READ (*(vu_char *)(CONFIG_SYS_BCSR + 8) & 1)
......
...@@ -212,6 +212,11 @@ ...@@ -212,6 +212,11 @@
* Port pins used for bit-banged MII communictions (if applicable). * Port pins used for bit-banged MII communictions (if applicable).
*/ */
#define MDIO_PORT 2 /* Port C */ #define MDIO_PORT 2 /* Port C */
#define MDIO_DECLARE volatile ioport_t *iop = ioport_addr ( \
(immap_t *) CONFIG_SYS_IMMR, MDIO_PORT )
#define MDC_DECLARE MDIO_DECLARE
#define MDIO_ACTIVE (iop->pdir |= 0x00400000) #define MDIO_ACTIVE (iop->pdir |= 0x00400000)
#define MDIO_TRISTATE (iop->pdir &= ~0x00400000) #define MDIO_TRISTATE (iop->pdir &= ~0x00400000)
#define MDIO_READ ((iop->pdat & 0x00400000) != 0) #define MDIO_READ ((iop->pdat & 0x00400000) != 0)
......
...@@ -93,6 +93,10 @@ ...@@ -93,6 +93,10 @@
# define CONFIG_SYS_FCC_PSMR (FCC_PSMR_FDE|FCC_PSMR_LPB) # define CONFIG_SYS_FCC_PSMR (FCC_PSMR_FDE|FCC_PSMR_LPB)
# define MDIO_PORT 0 /* Port A */ # define MDIO_PORT 0 /* Port A */
# define MDIO_DECLARE volatile ioport_t *iop = ioport_addr ( \
(immap_t *) CONFIG_SYS_IMMR, MDIO_PORT )
# define MDC_DECLARE MDIO_DECLARE
# define MDIO_DATA_PINMASK 0x00040000 /* Pin 13 */ # define MDIO_DATA_PINMASK 0x00040000 /* Pin 13 */
# define MDIO_CLCK_PINMASK 0x00080000 /* Pin 12 */ # define MDIO_CLCK_PINMASK 0x00080000 /* Pin 12 */
...@@ -110,6 +114,10 @@ ...@@ -110,6 +114,10 @@
# define CONFIG_SYS_FCC_PSMR (FCC_PSMR_FDE|FCC_PSMR_LPB) # define CONFIG_SYS_FCC_PSMR (FCC_PSMR_FDE|FCC_PSMR_LPB)
# define MDIO_PORT 0 /* Port A */ # define MDIO_PORT 0 /* Port A */
# define MDIO_DECLARE volatile ioport_t *iop = ioport_addr ( \
(immap_t *) CONFIG_SYS_IMMR, MDIO_PORT )
# define MDC_DECLARE MDIO_DECLARE
# define MDIO_DATA_PINMASK 0x00000040 /* Pin 25 */ # define MDIO_DATA_PINMASK 0x00000040 /* Pin 25 */
# define MDIO_CLCK_PINMASK 0x00000080 /* Pin 24 */ # define MDIO_CLCK_PINMASK 0x00000080 /* Pin 24 */
...@@ -127,6 +135,10 @@ ...@@ -127,6 +135,10 @@
# define CONFIG_SYS_FCC_PSMR (FCC_PSMR_FDE|FCC_PSMR_LPB) # define CONFIG_SYS_FCC_PSMR (FCC_PSMR_FDE|FCC_PSMR_LPB)
# define MDIO_PORT 0 /* Port A */ # define MDIO_PORT 0 /* Port A */
# define MDIO_DECLARE volatile ioport_t *iop = ioport_addr ( \
(immap_t *) CONFIG_SYS_IMMR, MDIO_PORT )
# define MDC_DECLARE MDIO_DECLARE
# define MDIO_DATA_PINMASK 0x00000100 /* Pin 23 */ # define MDIO_DATA_PINMASK 0x00000100 /* Pin 23 */
# define MDIO_CLCK_PINMASK 0x00000200 /* Pin 22 */ # define MDIO_CLCK_PINMASK 0x00000200 /* Pin 22 */
......
...@@ -101,6 +101,10 @@ ...@@ -101,6 +101,10 @@
* GPIO pins used for bit-banged MII communications * GPIO pins used for bit-banged MII communications
*/ */
#define MDIO_PORT 0 /* Port A */ #define MDIO_PORT 0 /* Port A */
#define MDIO_DECLARE volatile ioport_t *iop = ioport_addr ( \
(immap_t *) CONFIG_SYS_IMMR, MDIO_PORT )
#define MDC_DECLARE MDIO_DECLARE
#define CONFIG_SYS_MDIO_PIN 0x00200000 /* PA10 */ #define CONFIG_SYS_MDIO_PIN 0x00200000 /* PA10 */
#define CONFIG_SYS_MDC_PIN 0x00400000 /* PA9 */ #define CONFIG_SYS_MDC_PIN 0x00400000 /* PA9 */
......
...@@ -182,6 +182,10 @@ ...@@ -182,6 +182,10 @@
* Port pins used for bit-banged MII communictions (if applicable). * Port pins used for bit-banged MII communictions (if applicable).
*/ */
#define MDIO_PORT 2 /* Port C */ #define MDIO_PORT 2 /* Port C */
#define MDIO_DECLARE volatile ioport_t *iop = ioport_addr ( \
(immap_t *) CONFIG_SYS_IMMR, MDIO_PORT )
#define MDC_DECLARE MDIO_DECLARE
#define MDIO_ACTIVE (iop->pdir |= 0x00400000) #define MDIO_ACTIVE (iop->pdir |= 0x00400000)
#define MDIO_TRISTATE (iop->pdir &= ~0x00400000) #define MDIO_TRISTATE (iop->pdir &= ~0x00400000)
#define MDIO_READ ((iop->pdat & 0x00400000) != 0) #define MDIO_READ ((iop->pdat & 0x00400000) != 0)
......
...@@ -179,6 +179,10 @@ ...@@ -179,6 +179,10 @@
*/ */
#define MDIO_PORT 2 /* Port A=0, B=1, C=2, D=3 */ #define MDIO_PORT 2 /* Port A=0, B=1, C=2, D=3 */
#define MDIO_DECLARE volatile ioport_t *iop = ioport_addr ( \
(immap_t *) CONFIG_SYS_IMMR, MDIO_PORT )
#define MDC_DECLARE MDIO_DECLARE
#define MDIO_ACTIVE (iop->pdir |= 0x40000000) #define MDIO_ACTIVE (iop->pdir |= 0x40000000)
#define MDIO_TRISTATE (iop->pdir &= ~0x40000000) #define MDIO_TRISTATE (iop->pdir &= ~0x40000000)
#define MDIO_READ ((iop->pdat & 0x40000000) != 0) #define MDIO_READ ((iop->pdat & 0x40000000) != 0)
......
...@@ -201,6 +201,10 @@ ...@@ -201,6 +201,10 @@
* Port pins used for bit-banged MII communictions (if applicable). * Port pins used for bit-banged MII communictions (if applicable).
*/ */
#define MDIO_PORT 2 /* Port C */ #define MDIO_PORT 2 /* Port C */
#define MDIO_DECLARE volatile ioport_t *iop = ioport_addr ( \
(immap_t *) CONFIG_SYS_IMMR, MDIO_PORT )
#define MDC_DECLARE MDIO_DECLARE
#define MDIO_ACTIVE (iop->pdir |= 0x00400000) #define MDIO_ACTIVE (iop->pdir |= 0x00400000)
#define MDIO_TRISTATE (iop->pdir &= ~0x00400000) #define MDIO_TRISTATE (iop->pdir &= ~0x00400000)
#define MDIO_READ ((iop->pdat & 0x00400000) != 0) #define MDIO_READ ((iop->pdat & 0x00400000) != 0)
......
...@@ -293,6 +293,10 @@ ...@@ -293,6 +293,10 @@
* GPIO pins used for bit-banged MII communications * GPIO pins used for bit-banged MII communications
*/ */
#define MDIO_PORT 2 /* Port C */ #define MDIO_PORT 2 /* Port C */
#define MDIO_DECLARE volatile ioport_t *iop = ioport_addr ( \
(immap_t *) CONFIG_SYS_IMMR, MDIO_PORT )
#define MDC_DECLARE MDIO_DECLARE
#define MDIO_ACTIVE (iop->pdir |= 0x00400000) #define MDIO_ACTIVE (iop->pdir |= 0x00400000)
#define MDIO_TRISTATE (iop->pdir &= ~0x00400000) #define MDIO_TRISTATE (iop->pdir &= ~0x00400000)
#define MDIO_READ ((iop->pdat & 0x00400000) != 0) #define MDIO_READ ((iop->pdat & 0x00400000) != 0)
......
...@@ -19,6 +19,8 @@ ...@@ -19,6 +19,8 @@
| |
| COPYRIGHT I B M CORPORATION 1999 | COPYRIGHT I B M CORPORATION 1999
| LICENSED MATERIAL - PROGRAM PROPERTY OF I B M | LICENSED MATERIAL - PROGRAM PROPERTY OF I B M
|
| Additions (C) Copyright 2009 Industrie Dial Face S.p.A.
+----------------------------------------------------------------------------*/ +----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------+ /*----------------------------------------------------------------------------+
| |
...@@ -61,12 +63,33 @@ char *miiphy_get_current_dev (void); ...@@ -61,12 +63,33 @@ char *miiphy_get_current_dev (void);
void miiphy_listdev (void); void miiphy_listdev (void);
#define BB_MII_DEVNAME "bbmii" #ifdef CONFIG_BITBANGMII
#define BB_MII_DEVNAME "bb_miiphy"
struct bb_miiphy_bus {
char name[NAMESIZE];
int (*init)(struct bb_miiphy_bus *bus);
int (*mdio_active)(struct bb_miiphy_bus *bus);
int (*mdio_tristate)(struct bb_miiphy_bus *bus);
int (*set_mdio)(struct bb_miiphy_bus *bus, int v);
int (*get_mdio)(struct bb_miiphy_bus *bus, int *v);
int (*set_mdc)(struct bb_miiphy_bus *bus, int v);
int (*delay)(struct bb_miiphy_bus *bus);
#ifdef CONFIG_BITBANGMII_MULTI
void *priv;
#endif
};
extern struct bb_miiphy_bus bb_miiphy_buses[];
extern int bb_miiphy_buses_num;
void bb_miiphy_init (void);
int bb_miiphy_read (char *devname, unsigned char addr, int bb_miiphy_read (char *devname, unsigned char addr,
unsigned char reg, unsigned short *value); unsigned char reg, unsigned short *value);
int bb_miiphy_write (char *devname, unsigned char addr, int bb_miiphy_write (char *devname, unsigned char addr,
unsigned char reg, unsigned short value); unsigned char reg, unsigned short value);
#endif
/* phy seed setup */ /* phy seed setup */
#define AUTO 99 #define AUTO 99
......
...@@ -50,6 +50,10 @@ ...@@ -50,6 +50,10 @@
#include <onenand_uboot.h> #include <onenand_uboot.h>
#include <mmc.h> #include <mmc.h>
#ifdef CONFIG_BITBANGMII
#include <miiphy.h>
#endif
#ifdef CONFIG_DRIVER_SMC91111 #ifdef CONFIG_DRIVER_SMC91111
#include "../drivers/net/smc91111.h" #include "../drivers/net/smc91111.h"
#endif #endif
...@@ -417,6 +421,9 @@ extern void davinci_eth_set_mac_addr (const u_int8_t *addr); ...@@ -417,6 +421,9 @@ extern void davinci_eth_set_mac_addr (const u_int8_t *addr);
mmc_initialize (gd->bd); mmc_initialize (gd->bd);
#endif #endif
#ifdef CONFIG_BITBANGMII
bb_miiphy_init();
#endif
#if defined(CONFIG_CMD_NET) #if defined(CONFIG_CMD_NET)
#if defined(CONFIG_NET_MULTI) #if defined(CONFIG_NET_MULTI)
puts ("Net: "); puts ("Net: ");
......
...@@ -27,6 +27,10 @@ ...@@ -27,6 +27,10 @@
#include <version.h> #include <version.h>
#include <net.h> #include <net.h>
#ifdef CONFIG_BITBANGMII
#include <miiphy.h>
#endif
#include <asm/initcalls.h> #include <asm/initcalls.h>
#include <asm/sections.h> #include <asm/sections.h>
...@@ -337,6 +341,9 @@ void board_init_r(gd_t *new_gd, ulong dest_addr) ...@@ -337,6 +341,9 @@ void board_init_r(gd_t *new_gd, ulong dest_addr)
if (s) if (s)
load_addr = simple_strtoul(s, NULL, 16); load_addr = simple_strtoul(s, NULL, 16);
#ifdef CONFIG_BITBANGMII
bb_miiphy_init();
#endif
#if defined(CONFIG_CMD_NET) #if defined(CONFIG_CMD_NET)
s = getenv("bootfile"); s = getenv("bootfile");
if (s) if (s)
......
...@@ -26,6 +26,10 @@ ...@@ -26,6 +26,10 @@
#include <nand.h> /* cannot even include nand.h if it isnt configured */ #include <nand.h> /* cannot even include nand.h if it isnt configured */
#endif #endif
#ifdef CONFIG_BITBANGMII
#include <miiphy.h>
#endif
#if defined(CONFIG_POST) #if defined(CONFIG_POST)
#include <post.h> #include <post.h>
int post_flag; int post_flag;
...@@ -270,6 +274,9 @@ void board_init_f(ulong bootflag) ...@@ -270,6 +274,9 @@ void board_init_f(ulong bootflag)
static void board_net_init_r(bd_t *bd) static void board_net_init_r(bd_t *bd)
{ {
#ifdef CONFIG_BITBANGMII
bb_miiphy_init();
#endif
#ifdef CONFIG_CMD_NET #ifdef CONFIG_CMD_NET
uchar enetaddr[6]; uchar enetaddr[6];
char *s; char *s;
......
/* /*
* (C) Copyright 2002 * (C) Copyright 2002
* Daniel Engstrm, Omicron Ceti AB, daniel@omicron.se * Daniel Engstrm, Omicron Ceti AB, daniel@omicron.se
* *
* (C) Copyright 2002 * (C) Copyright 2002
* Wolfgang Denk, DENX Software Engineering, wd@denx.de. * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
...@@ -39,6 +39,10 @@ ...@@ -39,6 +39,10 @@
#include <ide.h> #include <ide.h>
#include <asm/u-boot-i386.h> #include <asm/u-boot-i386.h>
#ifdef CONFIG_BITBANGMII
#include <miiphy.h>
#endif
DECLARE_GLOBAL_DATA_PTR; DECLARE_GLOBAL_DATA_PTR;
extern long _i386boot_start; extern long _i386boot_start;
...@@ -351,6 +355,9 @@ void start_i386boot (void) ...@@ -351,6 +355,9 @@ void start_i386boot (void)
doc_init(); doc_init();
#endif #endif
#ifdef CONFIG_BITBANGMII
bb_miiphy_init();
#endif
#if defined(CONFIG_CMD_NET) #if defined(CONFIG_CMD_NET)
#if defined(CONFIG_NET_MULTI) #if defined(CONFIG_NET_MULTI)
WATCHDOG_RESET(); WATCHDOG_RESET();
......
...@@ -63,6 +63,10 @@ ...@@ -63,6 +63,10 @@
#include <spi.h> #include <spi.h>
#endif #endif
#ifdef CONFIG_BITBANGMII
#include <miiphy.h>
#endif
#include <nand.h> #include <nand.h>
DECLARE_GLOBAL_DATA_PTR; DECLARE_GLOBAL_DATA_PTR;
...@@ -630,6 +634,9 @@ void board_init_r (gd_t *id, ulong dest_addr) ...@@ -630,6 +634,9 @@ void board_init_r (gd_t *id, ulong dest_addr)
nand_init(); /* go init the NAND */ nand_init(); /* go init the NAND */
#endif #endif
#ifdef CONFIG_BITBANGMII
bb_miiphy_init();
#endif
#if defined(CONFIG_CMD_NET) #if defined(CONFIG_CMD_NET)
WATCHDOG_RESET(); WATCHDOG_RESET();
#if defined(FEC_ENET) #if defined(FEC_ENET)
......
...@@ -33,6 +33,10 @@ ...@@ -33,6 +33,10 @@
#include <onenand_uboot.h> #include <onenand_uboot.h>
#include <spi.h> #include <spi.h>
#ifdef CONFIG_BITBANGMII
#include <miiphy.h>
#endif
DECLARE_GLOBAL_DATA_PTR; DECLARE_GLOBAL_DATA_PTR;
#if ( ((CONFIG_ENV_ADDR+CONFIG_ENV_SIZE) < CONFIG_SYS_MONITOR_BASE) || \ #if ( ((CONFIG_ENV_ADDR+CONFIG_ENV_SIZE) < CONFIG_SYS_MONITOR_BASE) || \
...@@ -407,6 +411,9 @@ void board_init_r (gd_t *id, ulong dest_addr) ...@@ -407,6 +411,9 @@ void board_init_r (gd_t *id, ulong dest_addr)
misc_init_r (); misc_init_r ();
#endif #endif
#ifdef CONFIG_BITBANGMII
bb_miiphy_init();
#endif
#if defined(CONFIG_CMD_NET) #if defined(CONFIG_CMD_NET)
#if defined(CONFIG_NET_MULTI) #if defined(CONFIG_NET_MULTI)
puts ("Net: "); puts ("Net: ");
......
...@@ -83,6 +83,10 @@ ...@@ -83,6 +83,10 @@
#include <asm/mp.h> #include <asm/mp.h>
#endif #endif
#ifdef CONFIG_BITBANGMII
#include <miiphy.h>
#endif
#ifdef CONFIG_SYS_UPDATE_FLASH_SIZE #ifdef CONFIG_SYS_UPDATE_FLASH_SIZE
extern int update_flash_size (int flash_size); extern int update_flash_size (int flash_size);
#endif #endif
...@@ -942,6 +946,9 @@ void board_init_r (gd_t *id, ulong dest_addr) ...@@ -942,6 +946,9 @@ void board_init_r (gd_t *id, ulong dest_addr)
doc_init (); doc_init ();
#endif #endif
#ifdef CONFIG_BITBANGMII
bb_miiphy_init();
#endif
#if defined(CONFIG_CMD_NET) #if defined(CONFIG_CMD_NET)
#if defined(CONFIG_NET_MULTI) #if defined(CONFIG_NET_MULTI)
WATCHDOG_RESET (); WATCHDOG_RESET ();
......
...@@ -28,6 +28,10 @@ ...@@ -28,6 +28,10 @@
#include <net.h> #include <net.h>
#include <environment.h> #include <environment.h>
#ifdef CONFIG_BITBANGMII
#include <miiphy.h>
#endif
extern void malloc_bin_reloc (void); extern void malloc_bin_reloc (void);
extern int cpu_init(void); extern int cpu_init(void);
extern int board_init(void); extern int board_init(void);
...@@ -178,6 +182,9 @@ void sh_generic_init(void) ...@@ -178,6 +182,9 @@ void sh_generic_init(void)
#endif /* CONFIG_WATCHDOG*/ #endif /* CONFIG_WATCHDOG*/
#ifdef CONFIG_BITBANGMII
bb_miiphy_init();
#endif
#if defined(CONFIG_CMD_NET) #if defined(CONFIG_CMD_NET)
{ {
char *s; char *s;
......
...@@ -49,6 +49,10 @@ ...@@ -49,6 +49,10 @@
#include <ambapp.h> #include <ambapp.h>
#endif #endif
#ifdef CONFIG_BITBANGMII
#include <miiphy.h>
#endif
DECLARE_GLOBAL_DATA_PTR; DECLARE_GLOBAL_DATA_PTR;
/* Debug options /* Debug options
...@@ -405,6 +409,9 @@ void board_init_f(ulong bootflag) ...@@ -405,6 +409,9 @@ void board_init_f(ulong bootflag)
doc_init(); doc_init();
#endif #endif
#ifdef CONFIG_BITBANGMII
bb_miiphy_init();
#endif
#if defined(CONFIG_CMD_NET) #if defined(CONFIG_CMD_NET)
#if defined(CONFIG_NET_MULTI) #if defined(CONFIG_NET_MULTI)
WATCHDOG_RESET(); WATCHDOG_RESET();
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册