summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKevin Lo <kevlo@cvs.openbsd.org>2011-05-25 02:22:21 +0000
committerKevin Lo <kevlo@cvs.openbsd.org>2011-05-25 02:22:21 +0000
commit38906e83b50fb054c3a4f8d3cb05c48027812675 (patch)
treec8e1abec42969086d3fd7035957c4fc7f0f919d4
parent88ad985bb4bb835eec9debb620c6db9912e686e1 (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.c29
-rw-r--r--sys/dev/pci/if_alcreg.h9
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