2006-09-13 21:24:59 +04:00
/*
2005-09-24 06:54:21 +04:00
* drivers / net / gianfar_mii . h
*
* Gianfar Ethernet Driver - - MII Management Bus Implementation
* Driver for the MDIO bus controller in the Gianfar register space
*
* Author : Andy Fleming
2005-11-14 03:06:30 +03:00
* Maintainer : Kumar Gala
2005-09-24 06:54:21 +04:00
*
* Copyright ( c ) 2002 - 2004 Freescale Semiconductor , Inc .
*
* 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 .
*
*/
# ifndef __GIANFAR_MII_H
# define __GIANFAR_MII_H
# define MIIMIND_BUSY 0x00000001
# define MIIMIND_NOTVALID 0x00000004
# define MII_READ_COMMAND 0x00000001
# define GFAR_SUPPORTED (SUPPORTED_10baseT_Half \
2005-11-11 21:38:59 +03:00
| SUPPORTED_10baseT_Full \
2005-09-24 06:54:21 +04:00
| SUPPORTED_100baseT_Half \
| SUPPORTED_100baseT_Full \
| SUPPORTED_Autoneg \
| SUPPORTED_MII )
struct gfar_mii {
u32 miimcfg ; /* 0x.520 - MII Management Config Register */
u32 miimcom ; /* 0x.524 - MII Management Command Register */
u32 miimadd ; /* 0x.528 - MII Management Address Register */
u32 miimcon ; /* 0x.52c - MII Management Control Register */
u32 miimstat ; /* 0x.530 - MII Management Status Register */
u32 miimind ; /* 0x.534 - MII Management Indicator Register */
} ;
int gfar_mdio_read ( struct mii_bus * bus , int mii_id , int regnum ) ;
int gfar_mdio_write ( struct mii_bus * bus , int mii_id , int regnum , u16 value ) ;
2008-04-17 08:08:10 +04:00
int gfar_local_mdio_write ( struct gfar_mii __iomem * regs , int mii_id ,
int regnum , u16 value ) ;
int gfar_local_mdio_read ( struct gfar_mii __iomem * regs , int mii_id , int regnum ) ;
2005-09-24 06:54:21 +04:00
int __init gfar_mdio_init ( void ) ;
2007-07-26 09:52:34 +04:00
void gfar_mdio_exit ( void ) ;
2005-09-24 06:54:21 +04:00
# endif /* GIANFAR_PHY_H */