Module Name: src Committed By: msaitoh Date: Mon Aug 8 07:44:40 UTC 2022
Modified Files: src/sys/dev/pci: if_wm.c Log Message: Pass an error code to the upper layer instead of -1. Advised by knakahara. To generate a diff of this commit: cvs rdiff -u -r1.753 -r1.754 src/sys/dev/pci/if_wm.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/dev/pci/if_wm.c diff -u src/sys/dev/pci/if_wm.c:1.753 src/sys/dev/pci/if_wm.c:1.754 --- src/sys/dev/pci/if_wm.c:1.753 Mon Aug 8 05:45:29 2022 +++ src/sys/dev/pci/if_wm.c Mon Aug 8 07:44:40 2022 @@ -1,4 +1,4 @@ -/* $NetBSD: if_wm.c,v 1.753 2022/08/08 05:45:29 msaitoh Exp $ */ +/* $NetBSD: if_wm.c,v 1.754 2022/08/08 07:44:40 msaitoh Exp $ */ /* * Copyright (c) 2001, 2002, 2003, 2004 Wasabi Systems, Inc. @@ -82,7 +82,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: if_wm.c,v 1.753 2022/08/08 05:45:29 msaitoh Exp $"); +__KERNEL_RCSID(0, "$NetBSD: if_wm.c,v 1.754 2022/08/08 07:44:40 msaitoh Exp $"); #ifdef _KERNEL_OPT #include "opt_net_mpsafe.h" @@ -4745,7 +4745,7 @@ wm_write_smbus_addr(struct wm_softc *sc) rv = wm_gmii_hv_readreg_locked(sc->sc_dev, 2, HV_SMB_ADDR, &phy_data); if (rv != 0) - return -1; + return rv; phy_data &= ~HV_SMB_ADDR_ADDR; phy_data |= __SHIFTOUT(strap, STRAP_SMBUSADDR); @@ -11627,9 +11627,10 @@ wm_gmii_i82544_readreg(device_t dev, int struct wm_softc *sc = device_private(dev); int rv; - if (sc->phy.acquire(sc)) { + rv = sc->phy.acquire(sc); + if (rv != 0) { device_printf(dev, "%s: failed to get semaphore\n", __func__); - return -1; + return rv; } rv = wm_gmii_i82544_readreg_locked(dev, phy, reg, val); @@ -11678,9 +11679,10 @@ wm_gmii_i82544_writereg(device_t dev, in struct wm_softc *sc = device_private(dev); int rv; - if (sc->phy.acquire(sc)) { + rv = sc->phy.acquire(sc); + if (rv != 0) { device_printf(dev, "%s: failed to get semaphore\n", __func__); - return -1; + return rv; } rv = wm_gmii_i82544_writereg_locked(dev, phy, reg & MII_ADDRMASK, val); @@ -11730,14 +11732,15 @@ wm_gmii_i80003_readreg(device_t dev, int struct wm_softc *sc = device_private(dev); int page_select; uint16_t temp, temp2; - int rv = 0; + int rv; if (phy != 1) /* Only one PHY on kumeran bus */ return -1; - if (sc->phy.acquire(sc)) { + rv = sc->phy.acquire(sc); + if (rv != 0) { device_printf(dev, "%s: failed to get semaphore\n", __func__); - return -1; + return rv; } if ((reg & MII_ADDRMASK) < GG82563_MIN_ALT_REG) @@ -11793,9 +11796,10 @@ wm_gmii_i80003_writereg(device_t dev, in if (phy != 1) /* Only one PHY on kumeran bus */ return -1; - if (sc->phy.acquire(sc)) { + rv = sc->phy.acquire(sc); + if (rv != 0) { device_printf(dev, "%s: failed to get semaphore\n", __func__); - return -1; + return rv; } if ((reg & MII_ADDRMASK) < GG82563_MIN_ALT_REG) @@ -11848,9 +11852,10 @@ wm_gmii_bm_readreg(device_t dev, int phy uint16_t page = reg >> BME1000_PAGE_SHIFT; int rv; - if (sc->phy.acquire(sc)) { + rv = sc->phy.acquire(sc); + if (rv != 0) { device_printf(dev, "%s: failed to get semaphore\n", __func__); - return -1; + return rv; } if ((sc->sc_type != WM_T_82574) && (sc->sc_type != WM_T_82583)) @@ -11895,9 +11900,10 @@ wm_gmii_bm_writereg(device_t dev, int ph uint16_t page = reg >> BME1000_PAGE_SHIFT; int rv; - if (sc->phy.acquire(sc)) { + rv = sc->phy.acquire(sc); + if (rv != 0) { device_printf(dev, "%s: failed to get semaphore\n", __func__); - return -1; + return rv; } if ((sc->sc_type != WM_T_82574) && (sc->sc_type != WM_T_82583)) @@ -12113,9 +12119,11 @@ wm_gmii_hv_readreg(device_t dev, int phy DPRINTF(sc, WM_DEBUG_GMII, ("%s: %s called\n", device_xname(dev), __func__)); - if (sc->phy.acquire(sc)) { + + rv = sc->phy.acquire(sc); + if (rv != 0) { device_printf(dev, "%s: failed to get semaphore\n", __func__); - return -1; + return rv; } rv = wm_gmii_hv_readreg_locked(dev, phy, reg, val); @@ -12178,9 +12186,10 @@ wm_gmii_hv_writereg(device_t dev, int ph DPRINTF(sc, WM_DEBUG_GMII, ("%s: %s called\n", device_xname(dev), __func__)); - if (sc->phy.acquire(sc)) { + rv = sc->phy.acquire(sc); + if (rv != 0) { device_printf(dev, "%s: failed to get semaphore\n", __func__); - return -1; + return rv; } rv = wm_gmii_hv_writereg_locked(dev, phy, reg, val); @@ -12261,9 +12270,10 @@ wm_gmii_82580_readreg(device_t dev, int struct wm_softc *sc = device_private(dev); int rv; - if (sc->phy.acquire(sc) != 0) { + rv = sc->phy.acquire(sc); + if (rv != 0) { device_printf(dev, "%s: failed to get semaphore\n", __func__); - return -1; + return rv; } #ifdef DIAGNOSTIC @@ -12292,9 +12302,10 @@ wm_gmii_82580_writereg(device_t dev, int struct wm_softc *sc = device_private(dev); int rv; - if (sc->phy.acquire(sc) != 0) { + rv = sc->phy.acquire(sc); + if (rv != 0) { device_printf(dev, "%s: failed to get semaphore\n", __func__); - return -1; + return rv; } #ifdef DIAGNOSTIC @@ -12325,9 +12336,10 @@ wm_gmii_gs40g_readreg(device_t dev, int int rv; /* Acquire semaphore */ - if (sc->phy.acquire(sc)) { + rv = sc->phy.acquire(sc); + if (rv != 0) { device_printf(dev, "%s: failed to get semaphore\n", __func__); - return -1; + return rv; } /* Page select */ @@ -12360,9 +12372,10 @@ wm_gmii_gs40g_writereg(device_t dev, int int offset, rv; /* Acquire semaphore */ - if (sc->phy.acquire(sc)) { + rv = sc->phy.acquire(sc); + if (rv != 0) { device_printf(dev, "%s: failed to get semaphore\n", __func__); - return -1; + return rv; } /* Page select */ @@ -12645,9 +12658,10 @@ wm_sgmii_readreg(device_t dev, int phy, struct wm_softc *sc = device_private(dev); int rv; - if (sc->phy.acquire(sc)) { + rv = sc->phy.acquire(sc); + if (rv != 0) { device_printf(dev, "%s: failed to get semaphore\n", __func__); - return -1; + return rv; } rv = wm_sgmii_readreg_locked(dev, phy, reg, val); @@ -12702,9 +12716,10 @@ wm_sgmii_writereg(device_t dev, int phy, struct wm_softc *sc = device_private(dev); int rv; - if (sc->phy.acquire(sc) != 0) { + rv = sc->phy.acquire(sc); + if (rv != 0) { device_printf(dev, "%s: failed to get semaphore\n", __func__); - return -1; + return rv; } rv = wm_sgmii_writereg_locked(dev, phy, reg, val); @@ -13583,13 +13598,14 @@ static int wm_nvm_read_uwire(struct wm_softc *sc, int word, int wordcnt, uint16_t *data) { uint32_t reg, val; - int i; + int i, rv; DPRINTF(sc, WM_DEBUG_NVM, ("%s: %s called\n", device_xname(sc->sc_dev), __func__)); - if (sc->nvm.acquire(sc) != 0) - return -1; + rv = sc->nvm.acquire(sc); + if (rv != 0) + return rv; for (i = 0; i < wordcnt; i++) { /* Clear SK and DI. */ @@ -13747,13 +13763,14 @@ wm_nvm_read_spi(struct wm_softc *sc, int uint32_t reg, val; int i; uint8_t opc; - int rv = 0; + int rv; DPRINTF(sc, WM_DEBUG_NVM, ("%s: %s called\n", device_xname(sc->sc_dev), __func__)); - if (sc->nvm.acquire(sc) != 0) - return -1; + rv = sc->nvm.acquire(sc); + if (rv != 0) + return rv; /* Clear SK and CS. */ reg = CSR_READ(sc, WMREG_EECD) & ~(EECD_SK | EECD_CS); @@ -13821,13 +13838,14 @@ static int wm_nvm_read_eerd(struct wm_softc *sc, int offset, int wordcnt, uint16_t *data) { int i, eerd = 0; - int rv = 0; + int rv; DPRINTF(sc, WM_DEBUG_NVM, ("%s: %s called\n", device_xname(sc->sc_dev), __func__)); - if (sc->nvm.acquire(sc) != 0) - return -1; + rv = sc->nvm.acquire(sc); + if (rv != 0) + return rv; for (i = 0; i < wordcnt; i++) { eerd = ((offset + i) << EERD_ADDR_SHIFT) | EERD_START; @@ -14228,7 +14246,7 @@ wm_read_ich8_dword(struct wm_softc *sc, static int wm_nvm_read_ich8(struct wm_softc *sc, int offset, int words, uint16_t *data) { - int32_t rv = 0; + int rv; uint32_t flash_bank = 0; uint32_t act_offset = 0; uint32_t bank_offset = 0; @@ -14238,8 +14256,9 @@ wm_nvm_read_ich8(struct wm_softc *sc, in DPRINTF(sc, WM_DEBUG_NVM, ("%s: %s called\n", device_xname(sc->sc_dev), __func__)); - if (sc->nvm.acquire(sc) != 0) - return -1; + rv = sc->nvm.acquire(sc); + if (rv != 0) + return rv; /* * We need to know which is the valid flash bank. In the event @@ -14288,7 +14307,7 @@ wm_nvm_read_ich8(struct wm_softc *sc, in static int wm_nvm_read_spt(struct wm_softc *sc, int offset, int words, uint16_t *data) { - int32_t rv = 0; + int rv; uint32_t flash_bank = 0; uint32_t act_offset = 0; uint32_t bank_offset = 0; @@ -14298,8 +14317,9 @@ wm_nvm_read_spt(struct wm_softc *sc, int DPRINTF(sc, WM_DEBUG_NVM, ("%s: %s called\n", device_xname(sc->sc_dev), __func__)); - if (sc->nvm.acquire(sc) != 0) - return -1; + rv = sc->nvm.acquire(sc); + if (rv != 0) + return rv; /* * We need to know which is the valid flash bank. In the event @@ -14380,14 +14400,14 @@ wm_nvm_read_word_invm(struct wm_softc *s static int wm_nvm_read_invm(struct wm_softc *sc, int offset, int words, uint16_t *data) { - int rv = 0; - int i; + int i, rv; DPRINTF(sc, WM_DEBUG_NVM, ("%s: %s called\n", device_xname(sc->sc_dev), __func__)); - if (sc->nvm.acquire(sc) != 0) - return -1; + rv = sc->nvm.acquire(sc); + if (rv != 0) + return rv; for (i = 0; i < words; i++) { switch (offset + i) { @@ -15501,7 +15521,7 @@ static int wm_init_phy_workarounds_pchlan(struct wm_softc *sc) { uint32_t fwsm, reg; - int rv = 0; + int rv; DPRINTF(sc, WM_DEBUG_INIT, ("%s: %s called\n", device_xname(sc->sc_dev), __func__)); @@ -15517,7 +15537,7 @@ wm_init_phy_workarounds_pchlan(struct wm if (rv != 0) { DPRINTF(sc, WM_DEBUG_INIT, ("%s: %s: failed\n", device_xname(sc->sc_dev), __func__)); - return -1; + return rv; } /* The MAC-PHY interconnect may be in SMBus mode. If the PHY is @@ -15724,7 +15744,7 @@ wm_ulp_disable(struct wm_softc *sc) { uint32_t reg; uint16_t phyreg; - int i = 0, rv = 0; + int i = 0, rv; DPRINTF(sc, WM_DEBUG_INIT, ("%s: %s called\n", device_xname(sc->sc_dev), __func__)); @@ -15764,7 +15784,7 @@ wm_ulp_disable(struct wm_softc *sc) if (rv != 0) { DPRINTF(sc, WM_DEBUG_INIT, ("%s: %s: failed\n", device_xname(sc->sc_dev), __func__)); - return -1; + return rv; } /* Toggle LANPHYPC */ @@ -16086,7 +16106,7 @@ wm_resume_workarounds_pchlan(struct wm_s rv = wm_init_phy_workarounds_pchlan(sc); if (rv != 0) - return -1; + return rv; /* For i217 Intel Rapid Start Technology support when the system * is transitioning from Sx and no manageability engine is present @@ -16096,8 +16116,9 @@ wm_resume_workarounds_pchlan(struct wm_s if (sc->sc_phytype == WMPHY_I217) { uint16_t phy_reg; - if (sc->phy.acquire(sc) != 0) - return -1; + rv = sc->phy.acquire(sc); + if (rv != 0) + return rv; /* Clear Auto Enable LPI after link up */ sc->phy.readreg_locked(dev, 1, I217_LPI_GPIO_CTRL, &phy_reg); @@ -16361,7 +16382,7 @@ wm_set_eee_pchlan(struct wm_softc *sc) device_t dev = sc->sc_dev; struct ethercom *ec = &sc->sc_ethercom; uint16_t lpa, pcs_status, adv_addr, adv, lpi_ctrl, data; - int rv = 0; + int rv; switch (sc->sc_phytype) { case WMPHY_82579: @@ -16992,12 +17013,14 @@ static int wm_k1_gig_workaround_hv(struct wm_softc *sc, int link) { int k1_enable = sc->sc_nvm_k1_enabled; + int rv; DPRINTF(sc, WM_DEBUG_INIT, ("%s: %s called\n", device_xname(sc->sc_dev), __func__)); - if (sc->phy.acquire(sc) != 0) - return -1; + rv = sc->phy.acquire(sc); + if (rv != 0) + return rv; if (link) { k1_enable = 0;