diff options
author | Kevin Lo <kevlo@cvs.openbsd.org> | 2011-05-25 02:22:21 +0000 |
---|---|---|
committer | Kevin Lo <kevlo@cvs.openbsd.org> | 2011-05-25 02:22:21 +0000 |
commit | 38906e83b50fb054c3a4f8d3cb05c48027812675 (patch) | |
tree | c8e1abec42969086d3fd7035957c4fc7f0f919d4 | |
parent | 88ad985bb4bb835eec9debb620c6db9912e686e1 (diff) |
- For AR8132 fast ethernet controller, do not report 1000baseT
capability to mii(4).
- Limit DMA burst size to be less than or equal to 1024 bytes.
Controller does not seem to support more than 1024 bytes DMA burst.
- Do not touch CMB TX threshold register when CMB is not used.
From FreeBSD via Brad
- Properly initialize sc_product and alc_rev early enough in
alc_attach() with the PCI product id and PCI revision.
- Further sync if_alcvar.h changes from FreeBSD for L2C/L1D
addition commit which in OpenBSD has been merged into if_alcreg.h
From Brad; tested by Gabriel Linder and edd@.
-rw-r--r-- | sys/dev/pci/if_alc.c | 29 | ||||
-rw-r--r-- | sys/dev/pci/if_alcreg.h | 9 |
2 files changed, 25 insertions, 13 deletions
diff --git a/sys/dev/pci/if_alc.c b/sys/dev/pci/if_alc.c index 082cc794c8f..e02a3a56dfe 100644 --- a/sys/dev/pci/if_alc.c +++ b/sys/dev/pci/if_alc.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_alc.c,v 1.12 2011/05/18 14:20:27 sthen Exp $ */ +/* $OpenBSD: if_alc.c,v 1.13 2011/05/25 02:22:20 kevlo Exp $ */ /*- * Copyright (c) 2009, Pyun YongHyeon <yongari@FreeBSD.org> * All rights reserved. @@ -156,6 +156,16 @@ alc_miibus_readreg(struct device *dev, int phy, int reg) if (phy != sc->alc_phyaddr) return (0); + /* + * For AR8132 fast ethernet controller, do not report 1000baseT + * capability to mii(4). Even though AR8132 uses the same + * model/revision number of F1 gigabit PHY, the PHY has no + * ability to establish 1000baseT link. + */ + if ((sc->alc_flags & ALC_FLAG_FASTETHER) != 0 && + reg == MII_EXTSR) + return (0); + CSR_WRITE_4(sc, ALC_MDIO, MDIO_OP_EXECUTE | MDIO_OP_READ | MDIO_SUP_PREAMBLE | MDIO_CLK_25_4 | MDIO_REG_ADDR(reg)); for (i = ALC_PHY_TIMEOUT; i > 0; i--) { @@ -670,6 +680,10 @@ alc_attach(struct device *parent, struct device *self, void *aux) /* Set PHY address. */ sc->alc_phyaddr = ALC_PHY_ADDR; + /* Get PCI and chip id/revision. */ + sc->sc_product = PCI_PRODUCT(pa->pa_id); + sc->alc_rev = PCI_REVISION(pa->pa_class); + /* Initialize DMA parameters. */ sc->alc_dma_rd_burst = 0; sc->alc_dma_wr_burst = 0; @@ -690,6 +704,10 @@ alc_attach(struct device *parent, struct device *self, void *aux) sc->sc_dev.dv_xname, alc_dma_burst[sc->alc_dma_wr_burst]); } + if (alc_dma_burst[sc->alc_dma_rd_burst] > 1024) + sc->alc_dma_rd_burst = 3; + if (alc_dma_burst[sc->alc_dma_wr_burst] > 1024) + sc->alc_dma_wr_burst = 3; /* Clear data link and flow-control protocol error. */ val = CSR_READ_4(sc, ALC_PEX_UNC_ERR_SEV); val &= ~(PEX_UNC_ERR_SEV_DLP | PEX_UNC_ERR_SEV_FCP); @@ -747,7 +765,6 @@ alc_attach(struct device *parent, struct device *self, void *aux) * used in AR8132 can't establish gigabit link even if it * shows the same PHY model/revision number of AR8131. */ - sc->sc_product = PCI_PRODUCT(pa->pa_id); switch (sc->sc_product) { case PCI_PRODUCT_ATTANSIC_L2C_1: case PCI_PRODUCT_ATTANSIC_L2C_2: @@ -789,7 +806,7 @@ alc_attach(struct device *parent, struct device *self, void *aux) * Don't use Tx CMB. It is known to have silicon bug. */ sc->alc_flags |= ALC_FLAG_CMB_BUG; - sc->alc_rev = PCI_REVISION(pa->pa_class); + sc->alc_chip_rev = CSR_READ_4(sc, ALC_MASTER_CFG) >> MASTER_CHIP_REV_SHIFT; if (alcdebug) { @@ -2179,10 +2196,10 @@ alc_init(struct ifnet *ifp) */ CSR_WRITE_4(sc, ALC_INTR_RETRIG_TIMER, ALC_USECS(0)); /* Configure CMB. */ - CSR_WRITE_4(sc, ALC_CMB_TD_THRESH, 4); - if ((sc->alc_flags & ALC_FLAG_CMB_BUG) == 0) + if ((sc->alc_flags & ALC_FLAG_CMB_BUG) == 0) { + CSR_WRITE_4(sc, ALC_CMB_TD_THRESH, 4); CSR_WRITE_4(sc, ALC_CMB_TX_TIMER, ALC_USECS(5000)); - else + } else CSR_WRITE_4(sc, ALC_CMB_TX_TIMER, ALC_USECS(0)); /* * Hardware can be configured to issue SMB interrupt based diff --git a/sys/dev/pci/if_alcreg.h b/sys/dev/pci/if_alcreg.h index 67a6ce6347b..60d603ea9f1 100644 --- a/sys/dev/pci/if_alcreg.h +++ b/sys/dev/pci/if_alcreg.h @@ -1,4 +1,4 @@ -/* $OpenBSD: if_alcreg.h,v 1.3 2011/05/20 08:36:55 kevlo Exp $ */ +/* $OpenBSD: if_alcreg.h,v 1.4 2011/05/25 02:22:20 kevlo Exp $ */ /*- * Copyright (c) 2009, Pyun YongHyeon <yongari@FreeBSD.org> * All rights reserved. @@ -1007,13 +1007,8 @@ struct tx_desc { #define ALC_PROC_MAX (ALC_RX_RING_CNT - 1) #define ALC_PROC_DEFAULT (ALC_RX_RING_CNT / 4) -#define ALC_JUMBO_FRAMELEN (9 * 1024) -#define ALC_JUMBO_MTU \ - (ALC_JUMBO_FRAMELEN - sizeof(struct ether_vlan_header) - ETHER_CRC_LEN) -#define ALC_MAX_FRAMELEN (ETHER_MAX_LEN + EVL_ENCAPLEN) - /* - * The number of bits reserved for MSS in AR8121/AR8132 controllers + * The number of bits reserved for MSS in AR813x/AR815x controllers * are 13 bits. This limits the maximum interface MTU size in TSO * case(8191 + sizeof(struct ip) + sizeof(struct tcphdr)) as upper * stack should not generate TCP segments with MSS greater than the |