|
@@ -1,57 +0,0 @@
|
|
-/****************************************************************************
|
|
|
|
- * 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)
|
|
|
|
-{
|
|
|
|
- /* Read to clear LASI status register */
|
|
|
|
- efx_mdio_read(efx, MDIO_MMD_PMAPMD, MDIO_XP_LASI_STAT);
|
|
|
|
-
|
|
|
|
- efx_mdio_write(efx, 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 efx_mdio_read(efx, MDIO_MMD_PMAPMD, MDIO_XP_LASI_STAT);
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
-/* Turn off LASI interrupts */
|
|
|
|
-static inline void xenpack_disable_lasi_irqs(struct efx_nic *efx)
|
|
|
|
-{
|
|
|
|
- efx_mdio_write(efx, MDIO_MMD_PMAPMD, MDIO_XP_LASI_CTRL, 0);
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
-#endif /* EFX_XENPACK_H */
|
|
|