1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- /****************************************************************************
- * Driver for Solarflare Solarstorm network controllers and boards
- * Copyright 2006 Solarflare Communications Inc.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License version 2 as published
- * by the Free Software Foundation, incorporated herein by reference.
- */
- #ifndef EFX_XENPACK_H
- #define EFX_XENPACK_H
- /* Exported functions from Xenpack standard PHY control */
- #include "mdio_10g.h"
- /****************************************************************************/
- /* XENPACK MDIO register extensions */
- #define MDIO_XP_LASI_RX_CTRL (0x9000)
- #define MDIO_XP_LASI_TX_CTRL (0x9001)
- #define MDIO_XP_LASI_CTRL (0x9002)
- #define MDIO_XP_LASI_RX_STAT (0x9003)
- #define MDIO_XP_LASI_TX_STAT (0x9004)
- #define MDIO_XP_LASI_STAT (0x9005)
- /* Control/Status bits */
- #define XP_LASI_LS_ALARM (1 << 0)
- #define XP_LASI_TX_ALARM (1 << 1)
- #define XP_LASI_RX_ALARM (1 << 2)
- /* These two are Quake vendor extensions to the standard XENPACK defines */
- #define XP_LASI_LS_INTB (1 << 3)
- #define XP_LASI_TEST (1 << 7)
- /* Enable LASI interrupts for PHY */
- static inline void xenpack_enable_lasi_irqs(struct efx_nic *efx)
- {
- int reg;
- int phy_id = efx->mii.phy_id;
- /* Read to clear LASI status register */
- reg = mdio_clause45_read(efx, phy_id, MDIO_MMD_PMAPMD,
- MDIO_XP_LASI_STAT);
- mdio_clause45_write(efx, phy_id, MDIO_MMD_PMAPMD,
- MDIO_XP_LASI_CTRL, XP_LASI_LS_ALARM);
- }
- /* Read the LASI interrupt status to clear the interrupt. */
- static inline int xenpack_clear_lasi_irqs(struct efx_nic *efx)
- {
- /* Read to clear link status alarm */
- return mdio_clause45_read(efx, efx->mii.phy_id,
- MDIO_MMD_PMAPMD, MDIO_XP_LASI_STAT);
- }
- /* Turn off LASI interrupts */
- static inline void xenpack_disable_lasi_irqs(struct efx_nic *efx)
- {
- mdio_clause45_write(efx, efx->mii.phy_id, MDIO_MMD_PMAPMD,
- MDIO_XP_LASI_CTRL, 0);
- }
- #endif /* EFX_XENPACK_H */
|