mirror of
https://github.com/Fishwaldo/u-boot.git
synced 2025-03-25 08:31:33 +00:00
cpuat91: unbreak ethernet
* the following problems are met : config was set to use the new driver as a default but - RMII was not enabled for the new driver - the new driver didn't compile with RMII enabled - the new driver initialize a PHY at address O when the PHY of this board is at 1 thus we get "AT91 EMAC RMII: No PHY present" * to fix these problems, this patch : - enable RMII for the new driver - fix the wrong define used in the at91_emac.c - allow the config file to set a default phy address (and use 0 as a default as in the actual at91_emac.c driver) Signed-off-by: Eric Bénard <eric@eukrea.com> Signed-off-by: Ben Warren <biggerbadderben@gmail.com>
This commit is contained in:
parent
409943a989
commit
836cd45358
2 changed files with 25 additions and 16 deletions
|
@ -53,6 +53,10 @@
|
||||||
Please decrease the CONFIG_SYS_RX_ETH_BUFFER value
|
Please decrease the CONFIG_SYS_RX_ETH_BUFFER value
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef CONFIG_DRIVER_AT91EMAC_PHYADDR
|
||||||
|
#define CONFIG_DRIVER_AT91EMAC_PHYADDR 0
|
||||||
|
#endif
|
||||||
|
|
||||||
/* MDIO clock must not exceed 2.5 MHz, so enable MCK divider */
|
/* MDIO clock must not exceed 2.5 MHz, so enable MCK divider */
|
||||||
#if (AT91C_MASTER_CLOCK > 80000000)
|
#if (AT91C_MASTER_CLOCK > 80000000)
|
||||||
#define HCLK_DIV AT91_EMAC_CFG_MCLK_64
|
#define HCLK_DIV AT91_EMAC_CFG_MCLK_64
|
||||||
|
@ -198,12 +202,15 @@ static int at91emac_phy_reset(struct eth_device *netdev)
|
||||||
emac = (at91_emac_t *) netdev->iobase;
|
emac = (at91_emac_t *) netdev->iobase;
|
||||||
|
|
||||||
adv = ADVERTISE_CSMA | ADVERTISE_ALL;
|
adv = ADVERTISE_CSMA | ADVERTISE_ALL;
|
||||||
at91emac_write(emac, 0, MII_ADVERTISE, adv);
|
at91emac_write(emac, CONFIG_DRIVER_AT91EMAC_PHYADDR,
|
||||||
|
MII_ADVERTISE, adv);
|
||||||
VERBOSEP("%s: Starting autonegotiation...\n", netdev->name);
|
VERBOSEP("%s: Starting autonegotiation...\n", netdev->name);
|
||||||
at91emac_write(emac, 0, MII_BMCR, (BMCR_ANENABLE | BMCR_ANRESTART));
|
at91emac_write(emac, CONFIG_DRIVER_AT91EMAC_PHYADDR, MII_BMCR,
|
||||||
|
(BMCR_ANENABLE | BMCR_ANRESTART));
|
||||||
|
|
||||||
for (i = 0; i < 100000 / 100; i++) {
|
for (i = 0; i < 100000 / 100; i++) {
|
||||||
at91emac_read(emac, 0, MII_BMSR, &status);
|
at91emac_read(emac, CONFIG_DRIVER_AT91EMAC_PHYADDR,
|
||||||
|
MII_BMSR, &status);
|
||||||
if (status & BMSR_ANEGCOMPLETE)
|
if (status & BMSR_ANEGCOMPLETE)
|
||||||
break;
|
break;
|
||||||
udelay(100);
|
udelay(100);
|
||||||
|
@ -229,13 +236,15 @@ static int at91emac_phy_init(struct eth_device *netdev)
|
||||||
emac = (at91_emac_t *) netdev->iobase;
|
emac = (at91_emac_t *) netdev->iobase;
|
||||||
|
|
||||||
/* Check if the PHY is up to snuff... */
|
/* Check if the PHY is up to snuff... */
|
||||||
at91emac_read(emac, 0, MII_PHYSID1, &phy_id);
|
at91emac_read(emac, CONFIG_DRIVER_AT91EMAC_PHYADDR,
|
||||||
|
MII_PHYSID1, &phy_id);
|
||||||
if (phy_id == 0xffff) {
|
if (phy_id == 0xffff) {
|
||||||
printf("%s: No PHY present\n", netdev->name);
|
printf("%s: No PHY present\n", netdev->name);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
at91emac_read(emac, 0, MII_BMSR, &status);
|
at91emac_read(emac, CONFIG_DRIVER_AT91EMAC_PHYADDR,
|
||||||
|
MII_BMSR, &status);
|
||||||
|
|
||||||
if (!(status & BMSR_LSTATUS)) {
|
if (!(status & BMSR_LSTATUS)) {
|
||||||
/* Try to re-negotiate if we don't have link already. */
|
/* Try to re-negotiate if we don't have link already. */
|
||||||
|
@ -243,7 +252,8 @@ static int at91emac_phy_init(struct eth_device *netdev)
|
||||||
return 2;
|
return 2;
|
||||||
|
|
||||||
for (i = 0; i < 100000 / 100; i++) {
|
for (i = 0; i < 100000 / 100; i++) {
|
||||||
at91emac_read(emac, 0, MII_BMSR, &status);
|
at91emac_read(emac, CONFIG_DRIVER_AT91EMAC_PHYADDR,
|
||||||
|
MII_BMSR, &status);
|
||||||
if (status & BMSR_LSTATUS)
|
if (status & BMSR_LSTATUS)
|
||||||
break;
|
break;
|
||||||
udelay(100);
|
udelay(100);
|
||||||
|
@ -253,8 +263,10 @@ static int at91emac_phy_init(struct eth_device *netdev)
|
||||||
VERBOSEP("%s: link down\n", netdev->name);
|
VERBOSEP("%s: link down\n", netdev->name);
|
||||||
return 3;
|
return 3;
|
||||||
} else {
|
} else {
|
||||||
at91emac_read(emac, 0, MII_ADVERTISE, &adv);
|
at91emac_read(emac, CONFIG_DRIVER_AT91EMAC_PHYADDR,
|
||||||
at91emac_read(emac, 0, MII_LPA, &lpa);
|
MII_ADVERTISE, &adv);
|
||||||
|
at91emac_read(emac, CONFIG_DRIVER_AT91EMAC_PHYADDR,
|
||||||
|
MII_LPA, &lpa);
|
||||||
media = mii_nway_result(lpa & adv);
|
media = mii_nway_result(lpa & adv);
|
||||||
speed = (media & (ADVERTISE_100FULL | ADVERTISE_100HALF)
|
speed = (media & (ADVERTISE_100FULL | ADVERTISE_100HALF)
|
||||||
? 1 : 0);
|
? 1 : 0);
|
||||||
|
@ -271,7 +283,7 @@ int at91emac_UpdateLinkSpeed(at91_emac_t *emac)
|
||||||
{
|
{
|
||||||
unsigned short stat1;
|
unsigned short stat1;
|
||||||
|
|
||||||
at91emac_read(emac, 0, MII_BMSR, &stat1);
|
at91emac_read(emac, CONFIG_DRIVER_AT91EMAC_PHYADDR, MII_BMSR, &stat1);
|
||||||
|
|
||||||
if (!(stat1 & BMSR_LSTATUS)) /* link status up? */
|
if (!(stat1 & BMSR_LSTATUS)) /* link status up? */
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -364,7 +376,7 @@ static int at91emac_init(struct eth_device *netdev, bd_t *bd)
|
||||||
value = AT91_EMAC_CFG_CAF | AT91_EMAC_CFG_NBC |
|
value = AT91_EMAC_CFG_CAF | AT91_EMAC_CFG_NBC |
|
||||||
HCLK_DIV;
|
HCLK_DIV;
|
||||||
#ifdef CONFIG_RMII
|
#ifdef CONFIG_RMII
|
||||||
value |= AT91C_EMAC_RMII;
|
value |= AT91_EMAC_CFG_RMII;
|
||||||
#endif
|
#endif
|
||||||
writel(value, &emac->cfg);
|
writel(value, &emac->cfg);
|
||||||
|
|
||||||
|
|
|
@ -131,15 +131,12 @@
|
||||||
(CONFIG_SYS_MEMTEST_START + PHYS_SDRAM_SIZE - 512 * 1024)
|
(CONFIG_SYS_MEMTEST_START + PHYS_SDRAM_SIZE - 512 * 1024)
|
||||||
|
|
||||||
#define CONFIG_NET_MULTI 1
|
#define CONFIG_NET_MULTI 1
|
||||||
#ifdef CONFIG_NET_MULTI
|
|
||||||
#define CONFIG_DRIVER_AT91EMAC 1
|
#define CONFIG_DRIVER_AT91EMAC 1
|
||||||
#define CONFIG_SYS_RX_ETH_BUFFER 8
|
#define CONFIG_SYS_RX_ETH_BUFFER 8
|
||||||
#else
|
#define CONFIG_RMII 1
|
||||||
#define CONFIG_DRIVER_ETHER 1
|
#define CONFIG_MII 1
|
||||||
#endif
|
#define CONFIG_DRIVER_AT91EMAC_PHYADDR 1
|
||||||
#define CONFIG_NET_RETRY_COUNT 20
|
#define CONFIG_NET_RETRY_COUNT 20
|
||||||
#define CONFIG_AT91C_USE_RMII 1
|
|
||||||
#define CONFIG_PHY_ADDRESS (1 << 5)
|
|
||||||
#define CONFIG_KS8721_PHY 1
|
#define CONFIG_KS8721_PHY 1
|
||||||
|
|
||||||
#define CONFIG_SYS_FLASH_CFI 1
|
#define CONFIG_SYS_FLASH_CFI 1
|
||||||
|
|
Loading…
Add table
Reference in a new issue