Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp5044095pxj; Wed, 9 Jun 2021 07:57:50 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzh7cTRTX0xarnywH4iKTkDxfpO9iqzlmSv52EgVItf4Xv2HzICT09SrfL7geK5tcx0tpT0 X-Received: by 2002:a17:906:b855:: with SMTP id ga21mr281832ejb.550.1623250670323; Wed, 09 Jun 2021 07:57:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623250670; cv=none; d=google.com; s=arc-20160816; b=QvAAVI7KZrMewqabvUjxsTWcAnUWKxk4fKjQuX6GIUrk1lyBCfxbQnGQzUBdDJz6ko EAGEIx0MKcARXdssrdch0u9XkzgiAD7iCAH3aDE7yd7AcC4o42MG0bgQUuuHFLEbqU7t EIWQVT2AKzfHo0KfDJlZY8VSfWeNRnHyjknyYl/hNtSg0Qkl4/FZdBO39vxYdzgXrLV2 WHF5J/AffCKSqVJVSOjzevaY3cOrkBOovFsJy2d08jDiKF5o7D70bvDWhWHgpI4iCC8R tQwxU68ZqxZe+2suP05qjOhxMNefwsLGF+gzHE4F6wTVPFKxX/DkZZh+Wyv2A7S4Eapr 3cSw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=nf2BXQtJeETi1BZFFJMFnUxdAnmaMx2soeadxhnEBxM=; b=y24DXK0ohfYp9iOOHno5nWrM3lRwUAt5zwBU1KIoL0TkYLDYZWU3BgUQ8kIuR5gq8z 0/PUkIF/gO+XaA3OZBRkaE3refJlU3M1E3jqiCr88c/EPoM1j1H80zCThs+NhkMwd/BN PkW2UNs6h/ucE4lK1jZ0z0FplzCDfhp8XEsPESFubgzqS9AS2hSuAqO9duN0/vjQHeq/ vHDY8552B4tGOUyNmw5OyeG+GYCExjJZUWlBLDqHxaDwd33j3RSZYtEQsJrDfPN5m7MF fml9ljEcerKKGd8pfvHZ4SRduq/ZxPjOJnSvTSLO/82B/36aOI/5Uo4cr/uwyk0oZjnl MD4A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@svanheule.net header.s=mail1707 header.b=voC3qrNR; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=svanheule.net Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id go15si37306ejc.608.2021.06.09.07.57.25; Wed, 09 Jun 2021 07:57:50 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@svanheule.net header.s=mail1707 header.b=voC3qrNR; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=svanheule.net Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239426AbhFILsS (ORCPT + 99 others); Wed, 9 Jun 2021 07:48:18 -0400 Received: from polaris.svanheule.net ([84.16.241.116]:47162 "EHLO polaris.svanheule.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239391AbhFILsK (ORCPT ); Wed, 9 Jun 2021 07:48:10 -0400 Received: from terra.local.svanheule.net (unknown [IPv6:2a02:a03f:eafb:ee01:a92e:8520:f692:3284]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) (Authenticated sender: sander@svanheule.net) by polaris.svanheule.net (Postfix) with ESMTPSA id CED2D20B130; Wed, 9 Jun 2021 13:46:14 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=svanheule.net; s=mail1707; t=1623239175; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=nf2BXQtJeETi1BZFFJMFnUxdAnmaMx2soeadxhnEBxM=; b=voC3qrNRaGiQFlVVnRXgsrWBjQJ1VcDC+ekdHUG1qcyJglud5un2zlMGQYXHp2vOQoS0ml Jff+bJnLh44d5bQGCTHjtE7tm/N8hL7U3UB4bmnsQEy/qyhFwgqYi1cIGQeDmHjfhEBkZl 9bDz3nt5o7x5WlXHSGbAWQL35yb9RONVu2w7JswCBAbgOcciEcEcKP/1UFMDLQM3uDEEPq 8fPApUMf2QGvUAIwdMmBlKFo2TR47nb4hY4PoQQUdFtIoX9Ts5gt1GcMNAWTgprkYX6Twf U0vxziRNTggHhJVBXGaJZBhi94ZZGsMonnyzWCxMTn7r0S2Qok1Cfbmd+VOIyw== From: Sander Vanheule To: Mark Brown , Greg Kroah-Hartman , "Rafael J . Wysocki" , linux-kernel@vger.kernel.org Cc: Andy Shevchenko , Adrew Lunn , Sander Vanheule Subject: [PATCH 1/2] Revert "regmap: mdio: Add clause-45 support" Date: Wed, 9 Jun 2021 13:46:05 +0200 Message-Id: X-Mailer: git-send-email 2.31.1 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This reverts commit f083be9db060fbac09123d80bdffb2c001ac0e2b. There are currently no (planned) regmap users for C45 register access. Remove support for now, to reduce dead code. Signed-off-by: Sander Vanheule --- drivers/base/regmap/regmap-mdio.c | 70 +++++++------------------------ 1 file changed, 14 insertions(+), 56 deletions(-) diff --git a/drivers/base/regmap/regmap-mdio.c b/drivers/base/regmap/regmap-mdio.c index cfb23afb19eb..aee34bf2400e 100644 --- a/drivers/base/regmap/regmap-mdio.c +++ b/drivers/base/regmap/regmap-mdio.c @@ -7,14 +7,13 @@ #define REGVAL_MASK GENMASK(15, 0) #define REGNUM_C22_MASK GENMASK(4, 0) -/* Clause-45 mask includes the device type (5 bit) and actual register number (16 bit) */ -#define REGNUM_C45_MASK GENMASK(20, 0) -static int regmap_mdio_read(struct mdio_device *mdio_dev, u32 reg, unsigned int *val) +static int regmap_mdio_read(void *context, unsigned int reg, unsigned int *val) { + struct mdio_device *mdio_dev = context; int ret; - ret = mdiobus_read(mdio_dev->bus, mdio_dev->addr, reg); + ret = mdiobus_read(mdio_dev->bus, mdio_dev->addr, reg & REGNUM_C22_MASK); if (ret < 0) return ret; @@ -22,63 +21,27 @@ static int regmap_mdio_read(struct mdio_device *mdio_dev, u32 reg, unsigned int return 0; } -static int regmap_mdio_write(struct mdio_device *mdio_dev, u32 reg, unsigned int val) -{ - return mdiobus_write(mdio_dev->bus, mdio_dev->addr, reg, val); -} - -static int regmap_mdio_c22_read(void *context, unsigned int reg, unsigned int *val) -{ - struct mdio_device *mdio_dev = context; - - return regmap_mdio_read(mdio_dev, reg & REGNUM_C22_MASK, val); -} - -static int regmap_mdio_c22_write(void *context, unsigned int reg, unsigned int val) +static int regmap_mdio_write(void *context, unsigned int reg, unsigned int val) { struct mdio_device *mdio_dev = context; - return regmap_mdio_write(mdio_dev, reg & REGNUM_C22_MASK, val); + return mdiobus_write(mdio_dev->bus, mdio_dev->addr, reg & REGNUM_C22_MASK, val); } -static const struct regmap_bus regmap_mdio_c22_bus = { - .reg_write = regmap_mdio_c22_write, - .reg_read = regmap_mdio_c22_read, -}; - -static int regmap_mdio_c45_read(void *context, unsigned int reg, unsigned int *val) -{ - struct mdio_device *mdio_dev = context; - - return regmap_mdio_read(mdio_dev, MII_ADDR_C45 | (reg & REGNUM_C45_MASK), val); -} - -static int regmap_mdio_c45_write(void *context, unsigned int reg, unsigned int val) -{ - struct mdio_device *mdio_dev = context; - - return regmap_mdio_write(mdio_dev, MII_ADDR_C45 | (reg & REGNUM_C45_MASK), val); -} - -static const struct regmap_bus regmap_mdio_c45_bus = { - .reg_write = regmap_mdio_c45_write, - .reg_read = regmap_mdio_c45_read, +static const struct regmap_bus regmap_mdio_bus = { + .reg_write = regmap_mdio_write, + .reg_read = regmap_mdio_read, }; struct regmap *__regmap_init_mdio(struct mdio_device *mdio_dev, const struct regmap_config *config, struct lock_class_key *lock_key, const char *lock_name) { - struct regmap_bus *bus; - - if (config->reg_bits == 5 && config->val_bits == 16) - bus = ®map_mdio_c22_bus; - else if (config->reg_bits == 21 && config->val_bits == 16) - bus = ®map_mdio_c45_bus; - else + if (config->reg_bits != 5 || config->val_bits != 16) return ERR_PTR(-EOPNOTSUPP); - return __regmap_init(&mdio_dev->dev, bus, mdio_dev, config, lock_key, lock_name); + return __regmap_init(&mdio_dev->dev, ®map_mdio_bus, mdio_dev, config, + lock_key, lock_name); } EXPORT_SYMBOL_GPL(__regmap_init_mdio); @@ -86,16 +49,11 @@ struct regmap *__devm_regmap_init_mdio(struct mdio_device *mdio_dev, const struct regmap_config *config, struct lock_class_key *lock_key, const char *lock_name) { - const struct regmap_bus *bus; - - if (config->reg_bits == 5 && config->val_bits == 16) - bus = ®map_mdio_c22_bus; - else if (config->reg_bits == 21 && config->val_bits == 16) - bus = ®map_mdio_c45_bus; - else + if (config->reg_bits != 5 || config->val_bits != 16) return ERR_PTR(-EOPNOTSUPP); - return __devm_regmap_init(&mdio_dev->dev, bus, mdio_dev, config, lock_key, lock_name); + return __devm_regmap_init(&mdio_dev->dev, ®map_mdio_bus, mdio_dev, + config, lock_key, lock_name); } EXPORT_SYMBOL_GPL(__devm_regmap_init_mdio); -- 2.31.1