reset: sti: Provide ops .status() call-back
authorLee Jones <lee.jones@linaro.org>
Mon, 26 Oct 2015 10:56:09 +0000 (10:56 +0000)
committerPhilipp Zabel <p.zabel@pengutronix.de>
Mon, 16 Nov 2015 08:23:47 +0000 (09:23 +0100)
Signed-off-by: Lee Jones <lee.jones@linaro.org>
Signed-off-by: Philipp Zabel <p.zabel@pengutronix.de>
drivers/reset/sti/reset-syscfg.c

index a145cc066d4ad946dda020023243c96d75537fd2..a78e09c7825efd43f4ebd268769902277b978437 100644 (file)
@@ -110,10 +110,33 @@ static int syscfg_reset_dev(struct reset_controller_dev *rcdev,
        return syscfg_reset_deassert(rcdev, idx);
 }
 
+static int syscfg_reset_status(struct reset_controller_dev *rcdev,
+                              unsigned long idx)
+{
+       struct syscfg_reset_controller *rst = to_syscfg_reset_controller(rcdev);
+       const struct syscfg_reset_channel *ch;
+       u32 ret_val = 0;
+       int err;
+
+       if (idx >= rcdev->nr_resets)
+               return -EINVAL;
+
+       ch = &rst->channels[idx];
+       if (ch->ack)
+               err = regmap_field_read(ch->ack, &ret_val);
+       else
+               err = regmap_field_read(ch->reset, &ret_val);
+       if (err)
+               return err;
+
+       return rst->active_low ? !ret_val : !!ret_val;
+}
+
 static struct reset_control_ops syscfg_reset_ops = {
        .reset    = syscfg_reset_dev,
        .assert   = syscfg_reset_assert,
        .deassert = syscfg_reset_deassert,
+       .status   = syscfg_reset_status,
 };
 
 static int syscfg_reset_controller_register(struct device *dev,