[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20260112064958.3837756-1-rdunlap@infradead.org>
Date: Sun, 11 Jan 2026 22:49:58 -0800
From: Randy Dunlap <rdunlap@...radead.org>
To: linux-kernel@...r.kernel.org
Cc: Randy Dunlap <rdunlap@...radead.org>,
Robert Marko <robert.marko@...tura.hr>,
Philipp Zabel <p.zabel@...gutronix.de>,
Greg Kroah-Hartman <gregkh@...uxfoundation.org>,
Rob Herring <robh@...nel.org>,
Krzysztof Kozlowski <krzk+dt@...nel.org>,
Conor Dooley <conor+dt@...nel.org>,
devicetree@...r.kernel.org
Subject: [PATCH] reset: remove the reset-tn48m driver
The reset-tn48m driver is useless without the simple-mfd parent, which
is not present in the kernel tree, so remove it and references to it.
Fixes: 5cd3921d16b6 ("reset: Add Delta TN48M CPLD reset controller")
Signed-off-by: Randy Dunlap <rdunlap@...radead.org>
---
Based on v6.19-rc4.
Cc: Robert Marko <robert.marko@...tura.hr>
Cc: Philipp Zabel <p.zabel@...gutronix.de>
Cc: Greg Kroah-Hartman <gregkh@...uxfoundation.org>
Cc: Rob Herring <robh@...nel.org>
Cc: Krzysztof Kozlowski <krzk+dt@...nel.org>
Cc: Conor Dooley <conor+dt@...nel.org>
Cc: devicetree@...r.kernel.org
.../bindings/reset/delta,tn48m-reset.yaml | 35 ------
drivers/reset/Kconfig | 13 ---
drivers/reset/Makefile | 1 -
drivers/reset/reset-tn48m.c | 128 ---------------------
include/dt-bindings/reset/delta,tn48m-reset.h | 20 ----
5 files changed, 197 deletions(-)
diff --git a/Documentation/devicetree/bindings/reset/delta,tn48m-reset.yaml b/Documentation/devicetree/bindings/reset/delta,tn48m-reset.yaml
deleted file mode 100644
index 0e5ee8decc0d..000000000000
--- a/Documentation/devicetree/bindings/reset/delta,tn48m-reset.yaml
+++ /dev/null
@@ -1,35 +0,0 @@
-# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
-%YAML 1.2
----
-$id: http://devicetree.org/schemas/reset/delta,tn48m-reset.yaml#
-$schema: http://devicetree.org/meta-schemas/core.yaml#
-
-title: Delta Networks TN48M CPLD reset controller
-
-maintainers:
- - Robert Marko <robert.marko@...tura.hr>
-
-description: |
- This module is part of the Delta TN48M multi-function device. For more
- details see ../mfd/delta,tn48m-cpld.yaml.
-
- Reset controller modules provides resets for the following:
- * 88F7040 SoC
- * 88F6820 SoC
- * 98DX3265 switch MAC-s
- * 88E1680 PHY-s
- * 88E1512 PHY
- * PoE PSE controller
-
-properties:
- compatible:
- const: delta,tn48m-reset
-
- "#reset-cells":
- const: 1
-
-required:
- - compatible
- - "#reset-cells"
-
-additionalProperties: false
diff --git a/drivers/reset/Kconfig b/drivers/reset/Kconfig
index 6e5d6deffa7d..e7fca3e5d3b0 100644
--- a/drivers/reset/Kconfig
+++ b/drivers/reset/Kconfig
@@ -360,19 +360,6 @@ config RESET_TI_TPS380X
you wish to use the reset framework for such devices, say Y here.
Otherwise, say N.
-config RESET_TN48M_CPLD
- tristate "Delta Networks TN48M switch CPLD reset controller"
- depends on MFD_TN48M_CPLD || COMPILE_TEST
- default MFD_TN48M_CPLD
- help
- This enables the reset controller driver for the Delta TN48M CPLD.
- It provides reset signals for Armada 7040 and 385 SoC-s, Alleycat 3X
- switch MAC-s, Alaska OOB ethernet PHY, Quad Alaska ethernet PHY-s and
- Microchip PD69200 PoE PSE controller.
-
- This driver can also be built as a module. If so, the module will be
- called reset-tn48m.
-
config RESET_UNIPHIER
tristate "Reset controller driver for UniPhier SoCs"
depends on ARCH_UNIPHIER || COMPILE_TEST
diff --git a/drivers/reset/Makefile b/drivers/reset/Makefile
index 9c3e484dfd81..b6212c21b5b7 100644
--- a/drivers/reset/Makefile
+++ b/drivers/reset/Makefile
@@ -45,7 +45,6 @@ obj-$(CONFIG_RESET_TH1520) += reset-th1520.o
obj-$(CONFIG_RESET_TI_SCI) += reset-ti-sci.o
obj-$(CONFIG_RESET_TI_SYSCON) += reset-ti-syscon.o
obj-$(CONFIG_RESET_TI_TPS380X) += reset-tps380x.o
-obj-$(CONFIG_RESET_TN48M_CPLD) += reset-tn48m.o
obj-$(CONFIG_RESET_UNIPHIER) += reset-uniphier.o
obj-$(CONFIG_RESET_UNIPHIER_GLUE) += reset-uniphier-glue.o
obj-$(CONFIG_RESET_ZYNQ) += reset-zynq.o
diff --git a/drivers/reset/reset-tn48m.c b/drivers/reset/reset-tn48m.c
deleted file mode 100644
index 130027291b6e..000000000000
--- a/drivers/reset/reset-tn48m.c
+++ /dev/null
@@ -1,128 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0-only
-/*
- * Delta TN48M CPLD reset driver
- *
- * Copyright (C) 2021 Sartura Ltd.
- *
- * Author: Robert Marko <robert.marko@...tura.hr>
- */
-
-#include <linux/device.h>
-#include <linux/kernel.h>
-#include <linux/mod_devicetable.h>
-#include <linux/module.h>
-#include <linux/platform_device.h>
-#include <linux/regmap.h>
-#include <linux/reset-controller.h>
-
-#include <dt-bindings/reset/delta,tn48m-reset.h>
-
-#define TN48M_RESET_REG 0x10
-
-#define TN48M_RESET_TIMEOUT_US 125000
-#define TN48M_RESET_SLEEP_US 10
-
-struct tn48_reset_map {
- u8 bit;
-};
-
-struct tn48_reset_data {
- struct reset_controller_dev rcdev;
- struct regmap *regmap;
-};
-
-static const struct tn48_reset_map tn48m_resets[] = {
- [CPU_88F7040_RESET] = {0},
- [CPU_88F6820_RESET] = {1},
- [MAC_98DX3265_RESET] = {2},
- [PHY_88E1680_RESET] = {4},
- [PHY_88E1512_RESET] = {6},
- [POE_RESET] = {7},
-};
-
-static inline struct tn48_reset_data *to_tn48_reset_data(
- struct reset_controller_dev *rcdev)
-{
- return container_of(rcdev, struct tn48_reset_data, rcdev);
-}
-
-static int tn48m_control_reset(struct reset_controller_dev *rcdev,
- unsigned long id)
-{
- struct tn48_reset_data *data = to_tn48_reset_data(rcdev);
- unsigned int val;
-
- regmap_update_bits(data->regmap, TN48M_RESET_REG,
- BIT(tn48m_resets[id].bit), 0);
-
- return regmap_read_poll_timeout(data->regmap,
- TN48M_RESET_REG,
- val,
- val & BIT(tn48m_resets[id].bit),
- TN48M_RESET_SLEEP_US,
- TN48M_RESET_TIMEOUT_US);
-}
-
-static int tn48m_control_status(struct reset_controller_dev *rcdev,
- unsigned long id)
-{
- struct tn48_reset_data *data = to_tn48_reset_data(rcdev);
- unsigned int regval;
- int ret;
-
- ret = regmap_read(data->regmap, TN48M_RESET_REG, ®val);
- if (ret < 0)
- return ret;
-
- if (BIT(tn48m_resets[id].bit) & regval)
- return 0;
- else
- return 1;
-}
-
-static const struct reset_control_ops tn48_reset_ops = {
- .reset = tn48m_control_reset,
- .status = tn48m_control_status,
-};
-
-static int tn48m_reset_probe(struct platform_device *pdev)
-{
- struct tn48_reset_data *data;
- struct regmap *regmap;
-
- regmap = dev_get_regmap(pdev->dev.parent, NULL);
- if (!regmap)
- return -ENODEV;
-
- data = devm_kzalloc(&pdev->dev, sizeof(*data), GFP_KERNEL);
- if (!data)
- return -ENOMEM;
-
- data->regmap = regmap;
-
- data->rcdev.owner = THIS_MODULE;
- data->rcdev.ops = &tn48_reset_ops;
- data->rcdev.nr_resets = ARRAY_SIZE(tn48m_resets);
- data->rcdev.of_node = pdev->dev.of_node;
-
- return devm_reset_controller_register(&pdev->dev, &data->rcdev);
-}
-
-static const struct of_device_id tn48m_reset_of_match[] = {
- { .compatible = "delta,tn48m-reset" },
- { }
-};
-MODULE_DEVICE_TABLE(of, tn48m_reset_of_match);
-
-static struct platform_driver tn48m_reset_driver = {
- .driver = {
- .name = "delta-tn48m-reset",
- .of_match_table = tn48m_reset_of_match,
- },
- .probe = tn48m_reset_probe,
-};
-module_platform_driver(tn48m_reset_driver);
-
-MODULE_AUTHOR("Robert Marko <robert.marko@...tura.hr>");
-MODULE_DESCRIPTION("Delta TN48M CPLD reset driver");
-MODULE_LICENSE("GPL");
diff --git a/include/dt-bindings/reset/delta,tn48m-reset.h b/include/dt-bindings/reset/delta,tn48m-reset.h
deleted file mode 100644
index d4e9ed12de3e..000000000000
--- a/include/dt-bindings/reset/delta,tn48m-reset.h
+++ /dev/null
@@ -1,20 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-/*
- * Delta TN48M CPLD GPIO driver
- *
- * Copyright (C) 2021 Sartura Ltd.
- *
- * Author: Robert Marko <robert.marko@...tura.hr>
- */
-
-#ifndef _DT_BINDINGS_RESET_TN48M_H
-#define _DT_BINDINGS_RESET_TN48M_H
-
-#define CPU_88F7040_RESET 0
-#define CPU_88F6820_RESET 1
-#define MAC_98DX3265_RESET 2
-#define PHY_88E1680_RESET 3
-#define PHY_88E1512_RESET 4
-#define POE_RESET 5
-
-#endif /* _DT_BINDINGS_RESET_TN48M_H */
Powered by blists - more mailing lists