Lines Matching +full:sci +full:- +full:reset
1 // SPDX-License-Identifier: GPL-2.0-only
3 * Texas Instrument's System Control Interface (TI-SCI) reset driver
5 * Copyright (C) 2015-2017 Texas Instruments Incorporated - https://www.ti.com/
14 #include <linux/reset-controller.h>
18 * struct ti_sci_reset_control - reset control structure
19 * @dev_id: SoC-specific device identifier
20 * @reset_mask: reset mask to use for toggling reset
21 * @lock: synchronize reset_mask read-modify-writes
30 * struct ti_sci_reset_data - reset controller information structure
31 * @rcdev: reset controller entity
32 * @dev: reset controller device pointer
33 * @sci: TI SCI handle used for communication with system controller
34 * @idr: idr structure for mapping ids to reset control structures
39 const struct ti_sci_handle *sci; member
47 * ti_sci_reset_set() - program a device's reset
48 * @rcdev: reset controller entity
49 * @id: ID of the reset to toggle
53 * reset using the TI SCI protocol. The device's reset is asserted if the
55 * The mechanism itself is a read-modify-write procedure, the current device
56 * reset register is read using a TI SCI device operation, the new value is
57 * set or un-set using the reset's mask, and the new reset value written by
58 * using another TI SCI device operation.
66 const struct ti_sci_handle *sci = data->sci; in ti_sci_reset_set() local
67 const struct ti_sci_dev_ops *dev_ops = &sci->ops.dev_ops; in ti_sci_reset_set()
72 control = idr_find(&data->idr, id); in ti_sci_reset_set()
74 return -EINVAL; in ti_sci_reset_set()
76 mutex_lock(&control->lock); in ti_sci_reset_set()
78 ret = dev_ops->get_device_resets(sci, control->dev_id, &reset_state); in ti_sci_reset_set()
83 reset_state |= control->reset_mask; in ti_sci_reset_set()
85 reset_state &= ~control->reset_mask; in ti_sci_reset_set()
87 ret = dev_ops->set_device_resets(sci, control->dev_id, reset_state); in ti_sci_reset_set()
89 mutex_unlock(&control->lock); in ti_sci_reset_set()
95 * ti_sci_reset_assert() - assert device reset
96 * @rcdev: reset controller entity
97 * @id: ID of the reset to be asserted
99 * This function implements the reset driver op to assert a device's reset
100 * using the TI SCI protocol. This invokes the function ti_sci_reset_set()
102 * argument set to true for asserting the reset.
113 * ti_sci_reset_deassert() - deassert device reset
114 * @rcdev: reset controller entity
115 * @id: ID of the reset to be deasserted
117 * This function implements the reset driver op to deassert a device's reset
118 * using the TI SCI protocol. This invokes the function ti_sci_reset_set()
120 * argument set to false for deasserting the reset.
131 * ti_sci_reset_status() - check device reset status
132 * @rcdev: reset controller entity
133 * @id: ID of reset to be checked
135 * This function implements the reset driver op to return the status of a
136 * device's reset using the TI SCI protocol. The reset register value is read
137 * by invoking the TI SCI device operation .get_device_resets(), and the
138 * status of the specific reset is extracted and returned using this reset's
139 * reset mask.
141 * Return: 0 if reset is deasserted, or a non-zero value if reset is asserted
147 const struct ti_sci_handle *sci = data->sci; in ti_sci_reset_status() local
148 const struct ti_sci_dev_ops *dev_ops = &sci->ops.dev_ops; in ti_sci_reset_status()
153 control = idr_find(&data->idr, id); in ti_sci_reset_status()
155 return -EINVAL; in ti_sci_reset_status()
157 ret = dev_ops->get_device_resets(sci, control->dev_id, &reset_state); in ti_sci_reset_status()
161 return reset_state & control->reset_mask; in ti_sci_reset_status()
171 * ti_sci_reset_of_xlate() - translate a set of OF arguments to a reset ID
172 * @rcdev: reset controller entity
173 * @reset_spec: OF reset argument specifier
175 * This function performs the translation of the reset argument specifier
176 * values defined in a reset consumer device node. The function allocates a
177 * reset control structure for that device reset, and will be used by the
178 * driver for performing any reset functions on that reset. An idr structure
179 * is allocated and used to map to the reset control structure. This idr
180 * is used by the driver to do reset lookups.
190 if (WARN_ON(reset_spec->args_count != rcdev->of_reset_n_cells)) in ti_sci_reset_of_xlate()
191 return -EINVAL; in ti_sci_reset_of_xlate()
193 control = devm_kzalloc(data->dev, sizeof(*control), GFP_KERNEL); in ti_sci_reset_of_xlate()
195 return -ENOMEM; in ti_sci_reset_of_xlate()
197 control->dev_id = reset_spec->args[0]; in ti_sci_reset_of_xlate()
198 control->reset_mask = reset_spec->args[1]; in ti_sci_reset_of_xlate()
199 mutex_init(&control->lock); in ti_sci_reset_of_xlate()
201 return idr_alloc(&data->idr, control, 0, 0, GFP_KERNEL); in ti_sci_reset_of_xlate()
205 { .compatible = "ti,sci-reset", },
214 if (!pdev->dev.of_node) in ti_sci_reset_probe()
215 return -ENODEV; in ti_sci_reset_probe()
217 data = devm_kzalloc(&pdev->dev, sizeof(*data), GFP_KERNEL); in ti_sci_reset_probe()
219 return -ENOMEM; in ti_sci_reset_probe()
221 data->sci = devm_ti_sci_get_handle(&pdev->dev); in ti_sci_reset_probe()
222 if (IS_ERR(data->sci)) in ti_sci_reset_probe()
223 return PTR_ERR(data->sci); in ti_sci_reset_probe()
225 data->rcdev.ops = &ti_sci_reset_ops; in ti_sci_reset_probe()
226 data->rcdev.owner = THIS_MODULE; in ti_sci_reset_probe()
227 data->rcdev.of_node = pdev->dev.of_node; in ti_sci_reset_probe()
228 data->rcdev.of_reset_n_cells = 2; in ti_sci_reset_probe()
229 data->rcdev.of_xlate = ti_sci_reset_of_xlate; in ti_sci_reset_probe()
230 data->dev = &pdev->dev; in ti_sci_reset_probe()
231 idr_init(&data->idr); in ti_sci_reset_probe()
235 return reset_controller_register(&data->rcdev); in ti_sci_reset_probe()
242 reset_controller_unregister(&data->rcdev); in ti_sci_reset_remove()
244 idr_destroy(&data->idr); in ti_sci_reset_remove()
253 .name = "ti-sci-reset",
260 MODULE_DESCRIPTION("TI System Control Interface (TI SCI) Reset driver");