From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from NAM01-BY2-obe.outbound.protection.outlook.com (mail-by2nam01on0074.outbound.protection.outlook.com [104.47.34.74]) by dpdk.org (Postfix) with ESMTP id 3D7571B113; Sat, 29 Sep 2018 07:42:44 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=CAVIUMNETWORKS.onmicrosoft.com; s=selector1-cavium-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=5AeCgIcujCn4PUjS0Kety5sgSiIdV/+VFYA1pk7LVh4=; b=XsCfXjjCU/vVNA3C7OFFVLXM8dc1Csz4alErjUDIWZ0Iohy+dJmDR1qTFV9rGTgnNelpVoxfGexb/jqXBNrbH3RbCd37lhlNfP6OMgQZqLxtCHGoy/pcRBA5IK3OOSQws3Gq3qp6ijDRIgLayQk9LC/3om2G+W9LHZIHIdHyJEg= Received: from BYAPR07MB5365.namprd07.prod.outlook.com (20.177.125.18) by BYAPR07MB5717.namprd07.prod.outlook.com (20.178.0.75) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.1164.25; Sat, 29 Sep 2018 05:42:42 +0000 Received: from BYAPR07MB5365.namprd07.prod.outlook.com ([fe80::2047:9647:f196:bde0]) by BYAPR07MB5365.namprd07.prod.outlook.com ([fe80::2047:9647:f196:bde0%6]) with mapi id 15.20.1143.022; Sat, 29 Sep 2018 05:42:42 +0000 From: "Mody, Rasesh" To: "dev@dpdk.org" CC: "Mody, Rasesh" , "ferruh.yigit@intel.com" , Dept-Eng DPDK Dev , "stable@dpdk.org" Thread-Topic: [PATCH v2 5/5] net/bnx2x: fix to add phy lock Thread-Index: AQHUV7c97mR064CaJUKVqFU0tQ45tA== Date: Sat, 29 Sep 2018 05:42:41 +0000 Message-ID: <1538199734-23357-5-git-send-email-rasesh.mody@cavium.com> References: <1537394318-17682-1-git-send-email-rasesh.mody@cavium.com> In-Reply-To: <1537394318-17682-1-git-send-email-rasesh.mody@cavium.com> Accept-Language: en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-clientproxiedby: CO1PR15CA0075.namprd15.prod.outlook.com (2603:10b6:101:20::19) To BYAPR07MB5365.namprd07.prod.outlook.com (2603:10b6:a03:64::18) authentication-results: spf=none (sender IP is ) smtp.mailfrom=Rasesh.Mody@cavium.com; x-ms-exchange-messagesentrepresentingtype: 1 x-originating-ip: [198.186.1.5] x-ms-publictraffictype: Email x-microsoft-exchange-diagnostics: 1; BYAPR07MB5717; 6:93HQwyt7Tmn1gnv5qJ86Z5yq+eZBRC887Sdte1MtnER2gOCMhdBjVTYnomdXql5UzgQ03pCd2Klpu1yY+BH1AAjPk53o05p3vVkDx4kBkdZ+vXsX5swkRUy5y/nqQIbtZxUj9SkTuztMh4+GWWUIAyY5UO6LJYmYguLdUoXAvNTkdn52ShQE/YORF54jXVBmkkr9K9o7aRNE8Dx5xGg8CruT6uL5FFL9Gq1/bq8lKInmYfP0xw5ymm/W6v33+2pTN0qEBOJVHNLoTP7zf5bQYa9N2JO3uxu1smetT/1Mum6h7EWr3DsV8+juw6aqqS9L+peW/M48SD0HEjGTJ8wvXg0gkSApFZznopjpFgM8TtwkC7YKjGEdlXEvUBiprUBAsZikdyrOf8F+jeoCIul+W5qHBA2Pg4iN6pbw5g79Bduiw0uMHUpoXr8I6LJuGdlZF/pj5pp0Qyg7DcWYcw389g==; 5:UBvvMK0x8vjJ3cmKItfLJxgVVCjKVXUls6pJ0uW/bg6Fx9TySKo3jo/URwP6GvmGFj7VUNjIDTfs9ktV1Zu2uuks95mSQ79lefZp+NI7q3cOGiD8Efch3ANl+JGbQXXeVjN+0vX8mcv/eD97sZIDeO09vDRYi3BrUn5d4atUyRU=; 7:0ZmYvTy4aoNWd3m0GSaPz4GGeI4uZDUP0i97zxWkPiHUA8eucIRVLrzfGYnc/aEaBC5LPudo8uo68OSD8p7k47gFrK+TVTk2ogIFo/l02HZWoZPpgbZzFRbSF7qKTfy40PBXT80ziiQwXkJiu3nv+g66MhpGPHPNK8DKW5PXYeQb/NzXI4gBP7v8KIA9AqURp5CEDcSZT7O1MJm9tXIqsekGxoLJSMzCSVpesiEjf/A22v9FLndFyY3m0g0MeNwS x-ms-office365-filtering-correlation-id: e516adee-5627-4b5e-55a2-08d625ce5f48 x-microsoft-antispam: BCL:0; PCL:0; RULEID:(7020095)(4652040)(8989299)(4534165)(4627221)(201703031133081)(201702281549075)(8990200)(5600074)(711020)(2017052603328)(7153060)(7193020); SRVR:BYAPR07MB5717; x-ms-traffictypediagnostic: BYAPR07MB5717: x-microsoft-antispam-prvs: x-exchange-antispam-report-test: UriScan:; x-ms-exchange-senderadcheck: 1 x-exchange-antispam-report-cfa-test: BCL:0; PCL:0; RULEID:(8211001083)(6040522)(2401047)(8121501046)(5005006)(823301075)(10201501046)(93006095)(93001095)(3231355)(944501410)(52105095)(3002001)(149066)(150057)(6041310)(20161123560045)(20161123564045)(20161123562045)(20161123558120)(201703131423095)(201702281528075)(20161123555045)(201703061421075)(201703061406153)(201708071742011)(7699051); SRVR:BYAPR07MB5717; BCL:0; PCL:0; RULEID:; SRVR:BYAPR07MB5717; x-forefront-prvs: 0810818DA0 x-forefront-antispam-report: SFV:NSPM; SFS:(10009020)(1496009)(136003)(39860400002)(346002)(396003)(366004)(376002)(199004)(189003)(186003)(81156014)(81166006)(11346002)(6512007)(71190400001)(6486002)(8676002)(7736002)(53936002)(305945005)(446003)(6916009)(71200400001)(5660300001)(486006)(1730700003)(34290500001)(8936002)(2616005)(6436002)(76176011)(476003)(5640700003)(99286004)(105586002)(2351001)(52116002)(106356001)(54906003)(26005)(14444005)(256004)(68736007)(36756003)(2906002)(2501003)(102836004)(4326008)(316002)(86362001)(2900100001)(14454004)(97736004)(3846002)(6116002)(6506007)(72206003)(5250100002)(386003)(25786009)(478600001)(66066001); DIR:OUT; SFP:1101; SCL:1; SRVR:BYAPR07MB5717; H:BYAPR07MB5365.namprd07.prod.outlook.com; FPR:; SPF:None; LANG:en; PTR:InfoNoRecords; A:1; MX:1; received-spf: None (protection.outlook.com: cavium.com does not designate permitted sender hosts) x-microsoft-antispam-message-info: N8FCEeI2nCG3era8EuJ/VJIZF4hZjehUg+ZBiABridB+g6h7ZlzXrA7e7PRJAkDqk4s/4CXg5vQrP7sQvd1f5lsxr3n1iL58LtN09BqXet4m/A51QWvtbkDyurPpq4mZE1IXUnb8JYRmSw7YVcbpj40nG2U/IGaB2GQlyaANW7s3cTyYkj2Gr8zqr10oBZEsy/U8OSfqMaCqR8WTR+lTBgkaYGrh1jez5SwNxgoVdGoakafsmJPx3HIJJgH3moTMbqqZQisxvEnYAOU78NxXVRV4PJV77xPaDKw4uRxCVKzPr1BsvMGk0THqGuIieZaG4zMyvuo1X0ohP08bsEeknc274FsfbD8SPwy5cthtUp4= spamdiagnosticoutput: 1:99 spamdiagnosticmetadata: NSPM Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 X-OriginatorOrg: cavium.com X-MS-Exchange-CrossTenant-Network-Message-Id: e516adee-5627-4b5e-55a2-08d625ce5f48 X-MS-Exchange-CrossTenant-originalarrivaltime: 29 Sep 2018 05:42:42.0326 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 711e4ccf-2e9b-4bcf-a551-4094005b6194 X-MS-Exchange-Transport-CrossTenantHeadersStamped: BYAPR07MB5717 Subject: [dpdk-dev] [PATCH v2 5/5] net/bnx2x: fix to add phy lock X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sat, 29 Sep 2018 05:42:45 -0000 This patch adds phy_lock, acquire/release the lock when performing PHY transactions. Without this fix driver can run into synchronization issues with management FW when modifying PHY settings. Fixes: 540a211084a7 ("bnx2x: driver core") Cc: stable@dpdk.org Signed-off-by: Rasesh Mody --- drivers/net/bnx2x/bnx2x.c | 59 ++++++++++++++++++++++++++++++++++++-= ---- drivers/net/bnx2x/bnx2x.h | 7 +++++ drivers/net/bnx2x/ecore_reg.h | 1 + 3 files changed, 60 insertions(+), 7 deletions(-) diff --git a/drivers/net/bnx2x/bnx2x.c b/drivers/net/bnx2x/bnx2x.c index 0225bea..2797593 100644 --- a/drivers/net/bnx2x/bnx2x.c +++ b/drivers/net/bnx2x/bnx2x.c @@ -112,6 +112,7 @@ static uint8_t bnx2x_chk_parity_attn(struct bnx2x_softc= *sc, uint8_t * global, static void bnx2x_update_rx_prod(struct bnx2x_softc *sc, struct bnx2x_fastpath *fp, uint16_t rx_bd_prod, uint16_t rx_cq_prod); +static void bnx2x_link_report_locked(struct bnx2x_softc *sc); static void bnx2x_link_report(struct bnx2x_softc *sc); void bnx2x_link_status_update(struct bnx2x_softc *sc); static int bnx2x_alloc_mem(struct bnx2x_softc *sc); @@ -198,7 +199,8 @@ static int bnx2x_acquire_hw_lock(struct bnx2x_softc *sc= , uint32_t resource) uint32_t hw_lock_control_reg; int cnt; =20 - PMD_INIT_FUNC_TRACE(sc); + if (resource) + PMD_INIT_FUNC_TRACE(sc); =20 /* validate the resource is within range */ if (resource > HW_LOCK_MAX_RESOURCE_VALUE) { @@ -234,7 +236,8 @@ static int bnx2x_acquire_hw_lock(struct bnx2x_softc *sc= , uint32_t resource) DELAY(5000); } =20 - PMD_DRV_LOG(NOTICE, sc, "Resource lock timeout!"); + PMD_DRV_LOG(NOTICE, sc, "Resource 0x%x resource_bit 0x%x lock timeout!", + resource, resource_bit); return -1; } =20 @@ -245,13 +248,14 @@ static int bnx2x_release_hw_lock(struct bnx2x_softc *= sc, uint32_t resource) int func =3D SC_FUNC(sc); uint32_t hw_lock_control_reg; =20 - PMD_INIT_FUNC_TRACE(sc); + if (resource) + PMD_INIT_FUNC_TRACE(sc); =20 /* validate the resource is within range */ if (resource > HW_LOCK_MAX_RESOURCE_VALUE) { PMD_DRV_LOG(NOTICE, sc, - "resource 0x%x > HW_LOCK_MAX_RESOURCE_VALUE", - resource); + "(resource 0x%x > HW_LOCK_MAX_RESOURCE_VALUE)" + " resource_bit 0x%x", resource, resource_bit); return -1; } =20 @@ -275,6 +279,18 @@ static int bnx2x_release_hw_lock(struct bnx2x_softc *s= c, uint32_t resource) return 0; } =20 +static void bnx2x_acquire_phy_lock(struct bnx2x_softc *sc) +{ + BNX2X_PHY_LOCK(sc); + bnx2x_acquire_hw_lock(sc, HW_LOCK_RESOURCE_MDIO); +} + +static void bnx2x_release_phy_lock(struct bnx2x_softc *sc) +{ + bnx2x_release_hw_lock(sc, HW_LOCK_RESOURCE_MDIO); + BNX2X_PHY_UNLOCK(sc); +} + /* copy command into DMAE command memory and set DMAE command Go */ void bnx2x_post_dmae(struct bnx2x_softc *sc, struct dmae_command *dmae, in= t idx) { @@ -2903,7 +2919,7 @@ static void bnx2x_link_attn(struct bnx2x_softc *sc) } } =20 - bnx2x_link_report(sc); + bnx2x_link_report_locked(sc); =20 if (IS_MF(sc)) { bnx2x_link_sync_notify(sc); @@ -2942,6 +2958,7 @@ static void bnx2x_attn_int_asserted(struct bnx2x_soft= c *sc, uint32_t asserted) if (asserted & ATTN_HARD_WIRED_MASK) { if (asserted & ATTN_NIG_FOR_FUNC) { =20 + bnx2x_acquire_phy_lock(sc); /* save nig interrupt mask */ nig_mask =3D REG_RD(sc, nig_int_mask_addr); =20 @@ -3039,6 +3056,7 @@ static void bnx2x_attn_int_asserted(struct bnx2x_soft= c *sc, uint32_t asserted) =20 REG_WR(sc, nig_int_mask_addr, nig_mask); =20 + bnx2x_release_phy_lock(sc); } } =20 @@ -3838,8 +3856,10 @@ static void bnx2x_attn_int_deasserted3(struct bnx2x_= softc *sc, uint32_t attn) if (sc->link_vars.periodic_flags & ELINK_PERIODIC_FLAGS_LINK_EVENT) { /* sync with link */ + bnx2x_acquire_phy_lock(sc); sc->link_vars.periodic_flags &=3D ~ELINK_PERIODIC_FLAGS_LINK_EVENT; + bnx2x_release_phy_lock(sc); if (IS_MF(sc)) { bnx2x_link_sync_notify(sc); } @@ -4029,7 +4049,9 @@ static void bnx2x_attn_int_deasserted0(struct bnx2x_s= oftc *sc, uint32_t attn) } =20 if ((attn & sc->link_vars.aeu_int_mask) && sc->port.pmf) { + bnx2x_acquire_phy_lock(sc); elink_handle_module_detect_int(&sc->link_params); + bnx2x_release_phy_lock(sc); } =20 if (attn & HW_INTERRUT_ASSERT_SET_0) { @@ -6867,7 +6889,7 @@ static uint16_t bnx2x_get_mf_speed(struct bnx2x_softc= *sc) } =20 /* report link status to OS, should be called under phy_lock */ -static void bnx2x_link_report(struct bnx2x_softc *sc) +static void bnx2x_link_report_locked(struct bnx2x_softc *sc) { struct bnx2x_link_report_data cur_data; =20 @@ -6888,8 +6910,13 @@ static void bnx2x_link_report(struct bnx2x_softc *sc= ) return; } =20 + PMD_DRV_LOG(INFO, sc, "Change in link status : cur_data =3D %lx, last_rep= orted_link =3D %lx\n", + cur_data.link_report_flags, + sc->last_reported_link.link_report_flags); + sc->link_cnt++; =20 + PMD_DRV_LOG(INFO, sc, "link status change count =3D %x\n", sc->link_cnt); /* report new link params and remember the state for the next time */ rte_memcpy(&sc->last_reported_link, &cur_data, sizeof(cur_data)); =20 @@ -6941,6 +6968,14 @@ static void bnx2x_link_report(struct bnx2x_softc *sc= ) } } =20 +static void +bnx2x_link_report(struct bnx2x_softc *sc) +{ + bnx2x_acquire_phy_lock(sc); + bnx2x_link_report_locked(sc); + bnx2x_release_phy_lock(sc); +} + void bnx2x_link_status_update(struct bnx2x_softc *sc) { if (sc->state !=3D BNX2X_STATE_OPEN) { @@ -7019,6 +7054,8 @@ static int bnx2x_initial_phy_init(struct bnx2x_softc = *sc, int load_mode) =20 bnx2x_set_requested_fc(sc); =20 + bnx2x_acquire_phy_lock(sc); + if (load_mode =3D=3D LOAD_DIAG) { lp->loopback_mode =3D ELINK_LOOPBACK_XGXS; /* Prefer doing PHY loopback at 10G speed, if possible */ @@ -7038,6 +7075,8 @@ static int bnx2x_initial_phy_init(struct bnx2x_softc = *sc, int load_mode) =20 rc =3D elink_phy_init(&sc->link_params, &sc->link_vars); =20 + bnx2x_release_phy_lock(sc); + bnx2x_calc_fc_adv(sc); =20 if (sc->link_vars.link_up) { @@ -7088,7 +7127,9 @@ void bnx2x_periodic_callout(struct bnx2x_softc *sc) */ mb(); if (sc->port.pmf) { + bnx2x_acquire_phy_lock(sc); elink_period_func(&sc->link_params, &sc->link_vars); + bnx2x_release_phy_lock(sc); } } #ifdef BNX2X_PULSE @@ -9840,8 +9881,10 @@ static void bnx2x_common_init_phy(struct bnx2x_softc= *sc) shmem2_base[1] =3D SHMEM2_RD(sc, other_shmem2_base_addr); } =20 + bnx2x_acquire_phy_lock(sc); elink_common_init_phy(sc, shmem_base, shmem2_base, sc->devinfo.chip_id, 0); + bnx2x_release_phy_lock(sc); } =20 static void bnx2x_pf_disable(struct bnx2x_softc *sc) @@ -11320,7 +11363,9 @@ static int bnx2x_init_hw_func(struct bnx2x_softc *s= c) static void bnx2x_link_reset(struct bnx2x_softc *sc) { if (!BNX2X_NOMCP(sc)) { + bnx2x_acquire_phy_lock(sc); elink_lfa_reset(&sc->link_params, &sc->link_vars); + bnx2x_release_phy_lock(sc); } else { if (!CHIP_REV_IS_SLOW(sc)) { PMD_DRV_LOG(WARNING, sc, diff --git a/drivers/net/bnx2x/bnx2x.h b/drivers/net/bnx2x/bnx2x.h index 1cc5a6b..7478072 100644 --- a/drivers/net/bnx2x/bnx2x.h +++ b/drivers/net/bnx2x/bnx2x.h @@ -725,6 +725,13 @@ struct bnx2x_port { =20 uint32_t phy_addr; =20 + /* Used to synchronize phy accesses. */ + rte_spinlock_t phy_mtx; + char phy_mtx_name[32]; + +#define BNX2X_PHY_LOCK(sc) rte_spinlock_lock(&sc->port.phy_mtx) +#define BNX2X_PHY_UNLOCK(sc) rte_spinlock_unlock(&sc->port.phy_mtx) + /* * MCP scratchpad address for port specific statistics. * The device is responsible for writing statistcss diff --git a/drivers/net/bnx2x/ecore_reg.h b/drivers/net/bnx2x/ecore_reg.h index ae8a93b..d69e857 100644 --- a/drivers/net/bnx2x/ecore_reg.h +++ b/drivers/net/bnx2x/ecore_reg.h @@ -1967,6 +1967,7 @@ #define HW_LOCK_MAX_RESOURCE_VALUE 31 #define HW_LOCK_RESOURCE_DRV_FLAGS 10 #define HW_LOCK_RESOURCE_GPIO 1 +#define HW_LOCK_RESOURCE_MDIO 0 #define HW_LOCK_RESOURCE_NVRAM 12 #define HW_LOCK_RESOURCE_PORT0_ATT_MASK 3 #define HW_LOCK_RESOURCE_RECOVERY_LEADER_0 8 --=20 1.7.10.3