Skip to content

Commit aba86f7

Browse files
docularxupH5
authored andcommitted
reset: spacemit: Extract common K1 reset code
Extract the common reset controller code from the K1 driver into separate reset-spacemit-common.{c,h} files to prepare for additional SpacemiT SoCs that share the same reset controller architecture. The common code includes handlers for reset assert and deassert operations and probing for auxiliary bus devices. Changes during extraction: - Module ownership: Use dev->driver->owner instead of THIS_MODULE in spacemit_reset_controller_register() to correctly reference the calling driver's module. - Rename spacemit_reset_ids to spacemit_k1_reset_ids. - Define new namespace "RESET_SPACEMIT" for the exported common functions (spacemit_reset_probe) and update K1 driver to import it. This prepares for additional SpacemiT SoCs (K3) that share the same reset controller architecture. Reviewed-by: Alex Elder <elder@riscstar.com> Signed-off-by: Guodong Xu <guodong@riscstar.com> Reviewed-by: Yixun Lan <dlan@kernel.org> Link: https://lore.kernel.org/spacemit/20260114092742-GYC7933267@gentoo.org/ [1] Signed-off-by: Philipp Zabel <p.zabel@pengutronix.de>
1 parent 2875b4b commit aba86f7

5 files changed

Lines changed: 144 additions & 101 deletions

File tree

drivers/reset/spacemit/Kconfig

Lines changed: 14 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1,14 +1,25 @@
11
# SPDX-License-Identifier: GPL-2.0-only
22

3-
config RESET_SPACEMIT_K1
4-
tristate "SpacemiT K1 reset driver"
3+
menu "Reset support for SpacemiT platforms"
54
depends on ARCH_SPACEMIT || COMPILE_TEST
6-
depends on SPACEMIT_K1_CCU
5+
6+
config RESET_SPACEMIT_COMMON
7+
tristate
78
select AUXILIARY_BUS
9+
help
10+
Common reset controller infrastructure for SpacemiT SoCs.
11+
This provides shared code and helper functions used by
12+
reset drivers for various SpacemiT SoC families.
13+
14+
config RESET_SPACEMIT_K1
15+
tristate "Support for SpacemiT K1 SoC"
16+
depends on SPACEMIT_K1_CCU
17+
select RESET_SPACEMIT_COMMON
818
default SPACEMIT_K1_CCU
919
help
1020
Support for reset controller in SpacemiT K1 SoC.
1121
This driver works with the SpacemiT K1 clock controller
1222
unit (CCU) driver to provide reset control functionality
1323
for various peripherals and subsystems in the SoC.
1424

25+
endmenu

drivers/reset/spacemit/Makefile

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,2 +1,4 @@
11
# SPDX-License-Identifier: GPL-2.0
2+
obj-$(CONFIG_RESET_SPACEMIT_COMMON) += reset-spacemit-common.o
3+
24
obj-$(CONFIG_RESET_SPACEMIT_K1) += reset-spacemit-k1.o
Lines changed: 77 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,77 @@
1+
// SPDX-License-Identifier: GPL-2.0-only
2+
3+
/* SpacemiT reset controller driver - common implementation */
4+
5+
#include <linux/container_of.h>
6+
#include <linux/device.h>
7+
#include <linux/module.h>
8+
9+
#include <soc/spacemit/ccu.h>
10+
11+
#include "reset-spacemit-common.h"
12+
13+
static int spacemit_reset_update(struct reset_controller_dev *rcdev,
14+
unsigned long id, bool assert)
15+
{
16+
struct ccu_reset_controller *controller;
17+
const struct ccu_reset_data *data;
18+
u32 mask;
19+
u32 val;
20+
21+
controller = container_of(rcdev, struct ccu_reset_controller, rcdev);
22+
data = &controller->data->reset_data[id];
23+
mask = data->assert_mask | data->deassert_mask;
24+
val = assert ? data->assert_mask : data->deassert_mask;
25+
26+
return regmap_update_bits(controller->regmap, data->offset, mask, val);
27+
}
28+
29+
static int spacemit_reset_assert(struct reset_controller_dev *rcdev,
30+
unsigned long id)
31+
{
32+
return spacemit_reset_update(rcdev, id, true);
33+
}
34+
35+
static int spacemit_reset_deassert(struct reset_controller_dev *rcdev,
36+
unsigned long id)
37+
{
38+
return spacemit_reset_update(rcdev, id, false);
39+
}
40+
41+
static const struct reset_control_ops spacemit_reset_control_ops = {
42+
.assert = spacemit_reset_assert,
43+
.deassert = spacemit_reset_deassert,
44+
};
45+
46+
static int spacemit_reset_controller_register(struct device *dev,
47+
struct ccu_reset_controller *controller)
48+
{
49+
struct reset_controller_dev *rcdev = &controller->rcdev;
50+
51+
rcdev->ops = &spacemit_reset_control_ops;
52+
rcdev->owner = dev->driver->owner;
53+
rcdev->of_node = dev->of_node;
54+
rcdev->nr_resets = controller->data->count;
55+
56+
return devm_reset_controller_register(dev, &controller->rcdev);
57+
}
58+
59+
int spacemit_reset_probe(struct auxiliary_device *adev,
60+
const struct auxiliary_device_id *id)
61+
{
62+
struct spacemit_ccu_adev *rdev = to_spacemit_ccu_adev(adev);
63+
struct ccu_reset_controller *controller;
64+
struct device *dev = &adev->dev;
65+
66+
controller = devm_kzalloc(dev, sizeof(*controller), GFP_KERNEL);
67+
if (!controller)
68+
return -ENOMEM;
69+
controller->data = (const struct ccu_reset_controller_data *)id->driver_data;
70+
controller->regmap = rdev->regmap;
71+
72+
return spacemit_reset_controller_register(dev, controller);
73+
}
74+
EXPORT_SYMBOL_NS_GPL(spacemit_reset_probe, "RESET_SPACEMIT");
75+
76+
MODULE_DESCRIPTION("SpacemiT reset controller driver - common code");
77+
MODULE_LICENSE("GPL");
Lines changed: 42 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,42 @@
1+
/* SPDX-License-Identifier: GPL-2.0-only */
2+
/*
3+
* SpacemiT reset controller driver - common definitions
4+
*/
5+
6+
#ifndef _RESET_SPACEMIT_COMMON_H_
7+
#define _RESET_SPACEMIT_COMMON_H_
8+
9+
#include <linux/auxiliary_bus.h>
10+
#include <linux/regmap.h>
11+
#include <linux/reset-controller.h>
12+
#include <linux/types.h>
13+
14+
struct ccu_reset_data {
15+
u32 offset;
16+
u32 assert_mask;
17+
u32 deassert_mask;
18+
};
19+
20+
struct ccu_reset_controller_data {
21+
const struct ccu_reset_data *reset_data; /* array */
22+
size_t count;
23+
};
24+
25+
struct ccu_reset_controller {
26+
struct reset_controller_dev rcdev;
27+
const struct ccu_reset_controller_data *data;
28+
struct regmap *regmap;
29+
};
30+
31+
#define RESET_DATA(_offset, _assert_mask, _deassert_mask) \
32+
{ \
33+
.offset = (_offset), \
34+
.assert_mask = (_assert_mask), \
35+
.deassert_mask = (_deassert_mask), \
36+
}
37+
38+
/* Common probe function */
39+
int spacemit_reset_probe(struct auxiliary_device *adev,
40+
const struct auxiliary_device_id *id);
41+
42+
#endif /* _RESET_SPACEMIT_COMMON_H_ */

drivers/reset/spacemit/reset-spacemit-k1.c

Lines changed: 9 additions & 98 deletions
Original file line numberDiff line numberDiff line change
@@ -1,41 +1,13 @@
11
// SPDX-License-Identifier: GPL-2.0-only
22

3-
/* SpacemiT reset controller driver */
3+
/* SpacemiT K1 reset controller driver */
44

5-
#include <linux/auxiliary_bus.h>
6-
#include <linux/container_of.h>
7-
#include <linux/device.h>
85
#include <linux/module.h>
9-
#include <linux/regmap.h>
10-
#include <linux/reset-controller.h>
11-
#include <linux/types.h>
126

13-
#include <soc/spacemit/k1-syscon.h>
147
#include <dt-bindings/clock/spacemit,k1-syscon.h>
8+
#include <soc/spacemit/k1-syscon.h>
159

16-
struct ccu_reset_data {
17-
u32 offset;
18-
u32 assert_mask;
19-
u32 deassert_mask;
20-
};
21-
22-
struct ccu_reset_controller_data {
23-
const struct ccu_reset_data *reset_data; /* array */
24-
size_t count;
25-
};
26-
27-
struct ccu_reset_controller {
28-
struct reset_controller_dev rcdev;
29-
const struct ccu_reset_controller_data *data;
30-
struct regmap *regmap;
31-
};
32-
33-
#define RESET_DATA(_offset, _assert_mask, _deassert_mask) \
34-
{ \
35-
.offset = (_offset), \
36-
.assert_mask = (_assert_mask), \
37-
.deassert_mask = (_deassert_mask), \
38-
}
10+
#include "reset-spacemit-common.h"
3911

4012
static const struct ccu_reset_data k1_mpmu_resets[] = {
4113
[RESET_WDT] = RESET_DATA(MPMU_WDTPCR, BIT(2), 0),
@@ -214,91 +186,30 @@ static const struct ccu_reset_controller_data k1_apbc2_reset_data = {
214186
.count = ARRAY_SIZE(k1_apbc2_resets),
215187
};
216188

217-
static int spacemit_reset_update(struct reset_controller_dev *rcdev,
218-
unsigned long id, bool assert)
219-
{
220-
struct ccu_reset_controller *controller;
221-
const struct ccu_reset_data *data;
222-
u32 mask;
223-
u32 val;
224-
225-
controller = container_of(rcdev, struct ccu_reset_controller, rcdev);
226-
data = &controller->data->reset_data[id];
227-
mask = data->assert_mask | data->deassert_mask;
228-
val = assert ? data->assert_mask : data->deassert_mask;
229-
230-
return regmap_update_bits(controller->regmap, data->offset, mask, val);
231-
}
232-
233-
static int spacemit_reset_assert(struct reset_controller_dev *rcdev,
234-
unsigned long id)
235-
{
236-
return spacemit_reset_update(rcdev, id, true);
237-
}
238-
239-
static int spacemit_reset_deassert(struct reset_controller_dev *rcdev,
240-
unsigned long id)
241-
{
242-
return spacemit_reset_update(rcdev, id, false);
243-
}
244-
245-
static const struct reset_control_ops spacemit_reset_control_ops = {
246-
.assert = spacemit_reset_assert,
247-
.deassert = spacemit_reset_deassert,
248-
};
249-
250-
static int spacemit_reset_controller_register(struct device *dev,
251-
struct ccu_reset_controller *controller)
252-
{
253-
struct reset_controller_dev *rcdev = &controller->rcdev;
254-
255-
rcdev->ops = &spacemit_reset_control_ops;
256-
rcdev->owner = THIS_MODULE;
257-
rcdev->of_node = dev->of_node;
258-
rcdev->nr_resets = controller->data->count;
259-
260-
return devm_reset_controller_register(dev, &controller->rcdev);
261-
}
262-
263-
static int spacemit_reset_probe(struct auxiliary_device *adev,
264-
const struct auxiliary_device_id *id)
265-
{
266-
struct spacemit_ccu_adev *rdev = to_spacemit_ccu_adev(adev);
267-
struct ccu_reset_controller *controller;
268-
struct device *dev = &adev->dev;
269-
270-
controller = devm_kzalloc(dev, sizeof(*controller), GFP_KERNEL);
271-
if (!controller)
272-
return -ENOMEM;
273-
controller->data = (const struct ccu_reset_controller_data *)id->driver_data;
274-
controller->regmap = rdev->regmap;
275-
276-
return spacemit_reset_controller_register(dev, controller);
277-
}
278-
279189
#define K1_AUX_DEV_ID(_unit) \
280190
{ \
281191
.name = "spacemit_ccu.k1-" #_unit "-reset", \
282192
.driver_data = (kernel_ulong_t)&k1_ ## _unit ## _reset_data, \
283193
}
284194

285-
static const struct auxiliary_device_id spacemit_reset_ids[] = {
195+
static const struct auxiliary_device_id spacemit_k1_reset_ids[] = {
286196
K1_AUX_DEV_ID(mpmu),
287197
K1_AUX_DEV_ID(apbc),
288198
K1_AUX_DEV_ID(apmu),
289199
K1_AUX_DEV_ID(rcpu),
290200
K1_AUX_DEV_ID(rcpu2),
291201
K1_AUX_DEV_ID(apbc2),
292-
{ },
202+
{ /* sentinel */ }
293203
};
294-
MODULE_DEVICE_TABLE(auxiliary, spacemit_reset_ids);
204+
MODULE_DEVICE_TABLE(auxiliary, spacemit_k1_reset_ids);
295205

296206
static struct auxiliary_driver spacemit_k1_reset_driver = {
297207
.probe = spacemit_reset_probe,
298-
.id_table = spacemit_reset_ids,
208+
.id_table = spacemit_k1_reset_ids,
299209
};
300210
module_auxiliary_driver(spacemit_k1_reset_driver);
301211

212+
MODULE_IMPORT_NS("RESET_SPACEMIT");
302213
MODULE_AUTHOR("Alex Elder <elder@kernel.org>");
303-
MODULE_DESCRIPTION("SpacemiT reset controller driver");
214+
MODULE_DESCRIPTION("SpacemiT K1 reset controller driver");
304215
MODULE_LICENSE("GPL");

0 commit comments

Comments
 (0)