[PATCH v2 09/12] reset: starfive: Introduce assert_polarity

Philipp Zabel p.zabel at pengutronix.de
Fri May 15 02:24:12 PDT 2026


On Di, 2026-05-12 at 01:35 -0700, Changhuang Liang wrote:
> The JHB100 SoC supports inverted operations for reset
> assertion/deassertion, introducing the an assert_polarity field to
> distinguish between different operation logics.
> 
> Signed-off-by: Changhuang Liang <changhuang.liang at starfivetech.com>
> ---
>  drivers/reset/starfive/reset-starfive-common.c | 18 +++++++++++++++---
>  drivers/reset/starfive/reset-starfive-common.h |  6 ++++++
>  2 files changed, 21 insertions(+), 3 deletions(-)
> 
> diff --git a/drivers/reset/starfive/reset-starfive-common.c b/drivers/reset/starfive/reset-starfive-common.c
> index 8ea142ecbd15..c7289c2b2a28 100644
> --- a/drivers/reset/starfive/reset-starfive-common.c
> +++ b/drivers/reset/starfive/reset-starfive-common.c
> @@ -68,7 +68,7 @@ static int starfive_reset_update(struct reset_controller_dev *rcdev,
>  	reg_status = data->status + offset * sizeof(u32);
>  	done = data->asserted ? data->asserted[offset] & mask : 0;
>  
> -	if (!assert)
> +	if (data->info && data->info->assert_polarity == assert)
>  		done ^= mask;
>  
>  	spin_lock_irqsave(&data->lock, flags);
> @@ -90,13 +90,25 @@ static int starfive_reset_update(struct reset_controller_dev *rcdev,
>  static int starfive_reset_assert(struct reset_controller_dev *rcdev,
>  				 unsigned long id)
>  {
> -	return starfive_reset_update(rcdev, id, true);

Please keep this.

> +	struct starfive_reset *data = starfive_reset_from(rcdev);
> +	bool assert = true;
> +
> +	if (data->info && data->info->assert_polarity)
> +		assert = false;

And move this into starfive_reset_update().

Consider renaming assert_polarity to active_low or similar, to align
nomenclature with other drivers.

> +
> +	return starfive_reset_update(rcdev, id, assert);
>  }
>  
>  static int starfive_reset_deassert(struct reset_controller_dev *rcdev,
>  				   unsigned long id)
>  {
> -	return starfive_reset_update(rcdev, id, false);
> +	struct starfive_reset *data = starfive_reset_from(rcdev);
> +	bool deassert = false;
> +
> +	if (data->info && data->info->assert_polarity)
> +		deassert = true;

Same as for starfive_reset_assert().

regards
Philipp



More information about the linux-riscv mailing list