Skip to content

Commit 62d11b8

Browse files
Bartosz GolaszewskipH5
authored andcommitted
reset: don't overwrite fwnode_reset_n_cells
Fix a logic bug in reset_controller_register() where we set fwnode_reset_n_cells to 1 if fwnode is set and fwnode_xlate is not but we do it after assigning of_fwnode_handle(of_node) to fwnode. Modify the logic to: assign fwnode from of_node if applicable, if fwnode is still not set, try to get it from the device and only then check of_xlate and fwnode_xlate and either assign fwnode_reset_n_cells from OF or default to fwnode_reset_simple_xlate and fwnode_reset_n_cells = 1. Fixes: ba8dbbb ("reset: convert the core API to using firmware nodes") Reported-by: Mark Brown <broonie@kernel.org> Closes: https://lore.kernel.org/all/0b72286b-33dd-4bc9-8c0e-161c2f4baed8@sirena.org.uk/ Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@oss.qualcomm.com> Tested-by: Mark Brown <broonie@kernel.org> Reviewed-by: Philipp Zabel <p.zabel@pengutronix.de> Signed-off-by: Philipp Zabel <p.zabel@pengutronix.de>
1 parent 2737dcb commit 62d11b8

1 file changed

Lines changed: 7 additions & 6 deletions

File tree

drivers/reset/core.c

Lines changed: 7 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -132,20 +132,21 @@ int reset_controller_register(struct reset_controller_dev *rcdev)
132132
if ((rcdev->of_node && rcdev->fwnode) || (rcdev->of_xlate && rcdev->fwnode_xlate))
133133
return -EINVAL;
134134

135-
if (!rcdev->of_node && !rcdev->fwnode) {
135+
if (rcdev->of_node && !rcdev->fwnode)
136+
rcdev->fwnode = of_fwnode_handle(rcdev->of_node);
137+
138+
if (!rcdev->fwnode) {
136139
rcdev->fwnode = dev_fwnode(rcdev->dev);
137140
if (!rcdev->fwnode)
138141
return -EINVAL;
139142
}
140143

141-
if (rcdev->of_node) {
142-
rcdev->fwnode = of_fwnode_handle(rcdev->of_node);
144+
if (rcdev->of_xlate)
143145
rcdev->fwnode_reset_n_cells = rcdev->of_reset_n_cells;
144-
}
145146

146-
if (rcdev->fwnode && !rcdev->fwnode_xlate) {
147-
rcdev->fwnode_reset_n_cells = 1;
147+
if (!rcdev->fwnode_xlate && !rcdev->of_xlate) {
148148
rcdev->fwnode_xlate = fwnode_reset_simple_xlate;
149+
rcdev->fwnode_reset_n_cells = 1;
149150
}
150151

151152
INIT_LIST_HEAD(&rcdev->reset_control_head);

0 commit comments

Comments
 (0)