From patchwork Fri Apr 12 12:52:29 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Venkat Kumar Ande X-Patchwork-Id: 139254 X-Patchwork-Delegate: ferruh.yigit@amd.com Return-Path: X-Original-To: patchwork@inbox.dpdk.org Delivered-To: patchwork@inbox.dpdk.org Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id BA9E443E52; Fri, 12 Apr 2024 14:53:45 +0200 (CEST) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id A9DE64111B; Fri, 12 Apr 2024 14:53:45 +0200 (CEST) Received: from NAM10-MW2-obe.outbound.protection.outlook.com (mail-mw2nam10on2068.outbound.protection.outlook.com [40.107.94.68]) by mails.dpdk.org (Postfix) with ESMTP id B5ADA410F1 for ; Fri, 12 Apr 2024 14:53:43 +0200 (CEST) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=TBNYSUiTG4FP0y74Ym/dhq8pp63eK29r/vVM4YDAojVIVlqTCgABm+Q32lQcPhQcxYe6JSpOEh+RR3bYLkPUSXiqjf4pKtuwbSGg9+G7nnqgJVsoMhqHJfGwIk+KmVN9lYBf1Zpow8bjFTuxU+bA4aNkgGKDWKi1nnNj28n0vhX0YHKDqhXWFrOKxyFYJ+70K6HmxHujiEUi78V/0oX7T0/7mR0nsYjC8EKuYLl5Czn7BPpJpHu9tFjJ9I8pNkeW0dluotr1/UclwVpx5z3pf7t/wMBGllwflL5B98Lr0nsREnAmoxLFUT/nC0tqFcdxb1wZGt/jFWLpM+lCHpyS1A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=NlbS2YjsDoskzWTvgrUIKuu7imNPj1V9xk5mPuIe2ZQ=; b=lsY6sQDagvuFTD27SMphRrd6nXqXF8beV7Ujreu6Xc930lXwDITffZr3u4HQzTBfV2WB7SZ0sVko06oussg5gZ9c1j17HvBJic9OzpyAIBB8zyc4s/2bkS3WAKReId+CoLQYAf+zyxEeMPkTcbCOBD6v4qzvU87wLptbhArnGawEbmQEAs3ofVYQ5d3LiYnwfhBE8TfhVaDYI8slUexTPWWic4S7fzdXpOSdIJZCJPodhMg80k/POm/OTkyy0bA1eZSBwKHjDx+zTfvgumK33De/fTTgsSjWj1ttWuRM3TArMi/R493zrOYhfAVruan1xFSbP5ZRFAS2/vRNQqaUWw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=dpdk.org smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none (0) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amd.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=NlbS2YjsDoskzWTvgrUIKuu7imNPj1V9xk5mPuIe2ZQ=; b=lfFGPIJorweL5TuyjvXWRsQwVz4MhOe2WvRsEkuPyuvW+U1u5ekSyopQbS7uBkGxmSAefG6jY176y5AhF8wsOlUMZ7dTcFBqRJaUsP1XEYNYo1qANpmUastpbwA2u/04fyJEgsT3al4g5wMEfxAYw6dt+QMiEIyCgT8Rikf3ZLY= Received: from BL1P223CA0028.NAMP223.PROD.OUTLOOK.COM (2603:10b6:208:2c4::33) by IA1PR12MB6436.namprd12.prod.outlook.com (2603:10b6:208:3ac::12) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7409.46; Fri, 12 Apr 2024 12:53:38 +0000 Received: from BL6PEPF00020E64.namprd04.prod.outlook.com (2603:10b6:208:2c4:cafe::47) by BL1P223CA0028.outlook.office365.com (2603:10b6:208:2c4::33) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7409.46 via Frontend Transport; Fri, 12 Apr 2024 12:53:38 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 165.204.84.17) smtp.mailfrom=amd.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=amd.com; Received-SPF: Pass (protection.outlook.com: domain of amd.com designates 165.204.84.17 as permitted sender) receiver=protection.outlook.com; client-ip=165.204.84.17; helo=SATLEXMB04.amd.com; pr=C Received: from SATLEXMB04.amd.com (165.204.84.17) by BL6PEPF00020E64.mail.protection.outlook.com (10.167.249.25) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.7452.22 via Frontend Transport; Fri, 12 Apr 2024 12:53:38 +0000 Received: from cae-Lilac-RMB.amd.com (10.180.168.240) by SATLEXMB04.amd.com (10.181.40.145) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.35; Fri, 12 Apr 2024 07:53:36 -0500 From: Venkat Kumar Ande To: CC: , Venkat Kumar Ande Subject: [PATCH 04/24] net/axgbe: check mdio for non-zero ports and CL45 PHYs Date: Fri, 12 Apr 2024 08:52:29 -0400 Message-ID: <20240412125249.10625-4-VenkatKumar.Ande@amd.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20240412125249.10625-1-VenkatKumar.Ande@amd.com> References: <20240412125249.10625-1-VenkatKumar.Ande@amd.com> MIME-Version: 1.0 X-Originating-IP: [10.180.168.240] X-ClientProxiedBy: SATLEXMB04.amd.com (10.181.40.145) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: BL6PEPF00020E64:EE_|IA1PR12MB6436:EE_ X-MS-Office365-Filtering-Correlation-Id: 3a8a8428-961f-4138-4242-08dc5aef92d0 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: yB/2SthnB/pShxTbnRYMDqgT9+f6pDQDnIBUx6ohNw+264kUtleYJnfilv7x+CJ11+qNVaEZ61Ipe5admOcDMf17+tJOzNZLoJvZWFH0mUTDsXzYiedN/RfQOl8f5Bxufpw5rT+shK3vXcPRC28zfmP4oOTu5O9xtMUiNU8I+CehuMF52FSwLsmvFdWpQnFiHrJQQr7TECUbvNOOdZOVEng0ig4buCzpcGFUHCvL9yS1+oiQmkR/flxS7MS3OcIuTssvegzGxadnHTnMlhs1nME7L6TkNrf7lG+9ArJ3eCRk4EWHVFVzWnpX4DYrf2Z9lR61cZ+SzG4xuk43hggodZuTK6a/q5u4r5AM/8z+r1sI9bamhdTFuU7tis/sTW7UT/HkF6wl4GACDrHSm4L44oflOcFv7Mnwjb15zyACs4k985PIenznBMCS6avGIGSpzf56lqrb4pyCISUwy549HX/3auPQHT44hD/Aw7xFYElrpEtQIGqtoXYDkEYmR6sJbhJCp516gzHQU58Ax9akFua7+fneIOJiM9NwRI2KCpBzzZ1fPuHEeA5FOYOWD823Pt4FZQvy6UufazgJTC372J5wNr66hyIFr6nlwSPugutlW/+fIv/mMStBmAMyjLZdz1KQNtzVjOqHK2RM9LaZpF7NtypeK6iShgQKsZ1dYbRcHNLfMDZl3zUvVAn0t7UxwhwmeWG/aoJYxpdCsDbwoZV9JHG/WZ4F5CathGHC0nJ+sG/iG9J4NWikIFStq4Ps X-Forefront-Antispam-Report: CIP:165.204.84.17; CTRY:US; LANG:en; SCL:1; SRV:; IPV:CAL; SFV:NSPM; H:SATLEXMB04.amd.com; PTR:InfoDomainNonexistent; CAT:NONE; SFS:(13230031)(376005)(1800799015)(82310400014)(36860700004); DIR:OUT; SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 12 Apr 2024 12:53:38.6104 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 3a8a8428-961f-4138-4242-08dc5aef92d0 X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=3dd8961f-e488-4e60-8e11-a82d994e183d; Ip=[165.204.84.17]; Helo=[SATLEXMB04.amd.com] X-MS-Exchange-CrossTenant-AuthSource: BL6PEPF00020E64.namprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: IA1PR12MB6436 X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org The XGBE hardware has support for performing MDIO operations using an MDIO command request. The driver mistakenly uses the mdio port address as the MDIO command request device address instead of the MDIO command request port address. Additionally, the driver does not properly check for and create a clause 45 MDIO command. Check the supplied MDIO register to determine if the request is a clause 45 operation (MII_ADDR_C45). For a clause 45 operation, extract device address and register number from the supplied MDIO register and use them to set the MDIO command request device address and register number fields. For a clause 22 operation, the MDIO request device address is set to zero and the MDIO command request register number is set to the supplied MDIO register. In either case, the supplied MDIO port address is used as the MDIO command request port address. Signed-off-by: Venkat Kumar Ande --- drivers/net/axgbe/axgbe_common.h | 2 -- drivers/net/axgbe/axgbe_dev.c | 22 ++++++++++++++++------ 2 files changed, 16 insertions(+), 8 deletions(-) diff --git a/drivers/net/axgbe/axgbe_common.h b/drivers/net/axgbe/axgbe_common.h index a5d11c5832..51532fb34a 100644 --- a/drivers/net/axgbe/axgbe_common.h +++ b/drivers/net/axgbe/axgbe_common.h @@ -407,8 +407,6 @@ #define MAC_MDIOSCAR_PA_WIDTH 5 #define MAC_MDIOSCAR_RA_INDEX 0 #define MAC_MDIOSCAR_RA_WIDTH 16 -#define MAC_MDIOSCAR_REG_INDEX 0 -#define MAC_MDIOSCAR_REG_WIDTH 21 #define MAC_MDIOSCCDR_BUSY_INDEX 22 #define MAC_MDIOSCCDR_BUSY_WIDTH 1 #define MAC_MDIOSCCDR_CMD_INDEX 16 diff --git a/drivers/net/axgbe/axgbe_dev.c b/drivers/net/axgbe/axgbe_dev.c index 6a7fddffca..3389954aa6 100644 --- a/drivers/net/axgbe/axgbe_dev.c +++ b/drivers/net/axgbe/axgbe_dev.c @@ -63,15 +63,27 @@ static int mdio_complete(struct axgbe_port *pdata) return 0; } +static unsigned int axgbe_create_mdio_sca(int port, int reg) +{ + unsigned int mdio_sca, da; + + da = (reg & MII_ADDR_C45) ? reg >> 16 : 0; + + mdio_sca = 0; + AXGMAC_SET_BITS(mdio_sca, MAC_MDIOSCAR, RA, reg); + AXGMAC_SET_BITS(mdio_sca, MAC_MDIOSCAR, PA, port); + AXGMAC_SET_BITS(mdio_sca, MAC_MDIOSCAR, DA, da); + + return mdio_sca; +} + static int axgbe_write_ext_mii_regs(struct axgbe_port *pdata, int addr, int reg, u16 val) { unsigned int mdio_sca, mdio_sccd; uint64_t timeout; - mdio_sca = 0; - AXGMAC_SET_BITS(mdio_sca, MAC_MDIOSCAR, REG, reg); - AXGMAC_SET_BITS(mdio_sca, MAC_MDIOSCAR, DA, addr); + mdio_sca = axgbe_create_mdio_sca(addr, reg); AXGMAC_IOWRITE(pdata, MAC_MDIOSCAR, mdio_sca); mdio_sccd = 0; @@ -97,9 +109,7 @@ static int axgbe_read_ext_mii_regs(struct axgbe_port *pdata, int addr, unsigned int mdio_sca, mdio_sccd; uint64_t timeout; - mdio_sca = 0; - AXGMAC_SET_BITS(mdio_sca, MAC_MDIOSCAR, REG, reg); - AXGMAC_SET_BITS(mdio_sca, MAC_MDIOSCAR, DA, addr); + mdio_sca = axgbe_create_mdio_sca(addr, reg); AXGMAC_IOWRITE(pdata, MAC_MDIOSCAR, mdio_sca); mdio_sccd = 0;