162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-or-later */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright (C) 2013 STMicroelectronics (R&D) Limited 462306a36Sopenharmony_ci * Author: Stephen Gallimore <stephen.gallimore@st.com> 562306a36Sopenharmony_ci */ 662306a36Sopenharmony_ci#ifndef __STI_RESET_SYSCFG_H 762306a36Sopenharmony_ci#define __STI_RESET_SYSCFG_H 862306a36Sopenharmony_ci 962306a36Sopenharmony_ci#include <linux/device.h> 1062306a36Sopenharmony_ci#include <linux/regmap.h> 1162306a36Sopenharmony_ci#include <linux/reset-controller.h> 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_ci/** 1462306a36Sopenharmony_ci * Reset channel description for a system configuration register based 1562306a36Sopenharmony_ci * reset controller. 1662306a36Sopenharmony_ci * 1762306a36Sopenharmony_ci * @compatible: Compatible string of the syscon regmap containing this 1862306a36Sopenharmony_ci * channel's control and ack (status) bits. 1962306a36Sopenharmony_ci * @reset: Regmap field description of the channel's reset bit. 2062306a36Sopenharmony_ci * @ack: Regmap field description of the channel's acknowledge bit. 2162306a36Sopenharmony_ci */ 2262306a36Sopenharmony_cistruct syscfg_reset_channel_data { 2362306a36Sopenharmony_ci const char *compatible; 2462306a36Sopenharmony_ci struct reg_field reset; 2562306a36Sopenharmony_ci struct reg_field ack; 2662306a36Sopenharmony_ci}; 2762306a36Sopenharmony_ci 2862306a36Sopenharmony_ci#define _SYSCFG_RST_CH(_c, _rr, _rb, _ar, _ab) \ 2962306a36Sopenharmony_ci { .compatible = _c, \ 3062306a36Sopenharmony_ci .reset = REG_FIELD(_rr, _rb, _rb), \ 3162306a36Sopenharmony_ci .ack = REG_FIELD(_ar, _ab, _ab), } 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_ci#define _SYSCFG_RST_CH_NO_ACK(_c, _rr, _rb) \ 3462306a36Sopenharmony_ci { .compatible = _c, \ 3562306a36Sopenharmony_ci .reset = REG_FIELD(_rr, _rb, _rb), } 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_ci/** 3862306a36Sopenharmony_ci * Description of a system configuration register based reset controller. 3962306a36Sopenharmony_ci * 4062306a36Sopenharmony_ci * @wait_for_ack: The controller will wait for reset assert and de-assert to 4162306a36Sopenharmony_ci * be "ack'd" in a channel's ack field. 4262306a36Sopenharmony_ci * @active_low: Are the resets in this controller active low, i.e. clearing 4362306a36Sopenharmony_ci * the reset bit puts the hardware into reset. 4462306a36Sopenharmony_ci * @nr_channels: The number of reset channels in this controller. 4562306a36Sopenharmony_ci * @channels: An array of reset channel descriptions. 4662306a36Sopenharmony_ci */ 4762306a36Sopenharmony_cistruct syscfg_reset_controller_data { 4862306a36Sopenharmony_ci bool wait_for_ack; 4962306a36Sopenharmony_ci bool active_low; 5062306a36Sopenharmony_ci int nr_channels; 5162306a36Sopenharmony_ci const struct syscfg_reset_channel_data *channels; 5262306a36Sopenharmony_ci}; 5362306a36Sopenharmony_ci 5462306a36Sopenharmony_ci/** 5562306a36Sopenharmony_ci * syscfg_reset_probe(): platform device probe function used by syscfg 5662306a36Sopenharmony_ci * reset controller drivers. This registers a reset 5762306a36Sopenharmony_ci * controller configured by the OF match data for 5862306a36Sopenharmony_ci * the compatible device which should be of type 5962306a36Sopenharmony_ci * "struct syscfg_reset_controller_data". 6062306a36Sopenharmony_ci * 6162306a36Sopenharmony_ci * @pdev: platform device 6262306a36Sopenharmony_ci */ 6362306a36Sopenharmony_ciint syscfg_reset_probe(struct platform_device *pdev); 6462306a36Sopenharmony_ci 6562306a36Sopenharmony_ci#endif /* __STI_RESET_SYSCFG_H */ 66