Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752256AbaKCIlt (ORCPT ); Mon, 3 Nov 2014 03:41:49 -0500 Received: from metis.ext.pengutronix.de ([92.198.50.35]:34325 "EHLO metis.ext.pengutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751256AbaKCIlq (ORCPT ); Mon, 3 Nov 2014 03:41:46 -0500 Message-ID: <1415004100.3060.1.camel@pengutronix.de> Subject: Re: [PATCH] reset: add socfpga_reset_status From: Philipp Zabel To: dinguyen@opensource.altera.com Cc: dinh.linux@gmail.com, s.trumtrar@pengutronix.de, atull@opensource.altera.com, linux-kernel@vger.kernel.org Date: Mon, 03 Nov 2014 09:41:40 +0100 In-Reply-To: <1414165990-23958-1-git-send-email-dinguyen@opensource.altera.com> References: <1414165990-23958-1-git-send-email-dinguyen@opensource.altera.com> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.12.6-1 Mime-Version: 1.0 Content-Transfer-Encoding: 7bit X-SA-Exim-Connect-IP: 2001:67c:670:100:96de:80ff:fec2:9969 X-SA-Exim-Mail-From: p.zabel@pengutronix.de X-SA-Exim-Scanned: No (on metis.ext.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Dinh, Am Freitag, den 24.10.2014, 10:53 -0500 schrieb dinguyen@opensource.altera.com: > From: Dinh Nguyen > > Populate the reset_status callback for SOCFPGA. > > Signed-off-by: Alan Tull > Signed-off-by: Dinh Nguyen > --- > drivers/reset/reset-socfpga.c | 18 ++++++++++++++++++ > 1 file changed, 18 insertions(+) > > diff --git a/drivers/reset/reset-socfpga.c b/drivers/reset/reset-socfpga.c > index 79c32ca..cd37849 100644 > --- a/drivers/reset/reset-socfpga.c > +++ b/drivers/reset/reset-socfpga.c > @@ -76,9 +76,27 @@ static int socfpga_reset_deassert(struct reset_controller_dev *rcdev, > return 0; > } > > +static int socfpga_reset_status(struct reset_controller_dev *rcdev, > + unsigned long id) > +{ > + struct socfpga_reset_data *data = container_of(rcdev, > + struct socfpga_reset_data, rcdev); > + int bank = id / BITS_PER_LONG; > + int offset = id % BITS_PER_LONG; > + unsigned long flags; > + u32 reg; > + > + spin_lock_irqsave(&data->lock, flags); > + reg = readl(data->membase + OFFSET_MODRST + (bank * NR_BANKS)); > + spin_unlock_irqrestore(&data->lock, flags); For the register read access, you don't need the lock. > + return !(reg & BIT(offset)); > +} > + > static struct reset_control_ops socfpga_reset_ops = { > .assert = socfpga_reset_assert, > .deassert = socfpga_reset_deassert, > + .status = socfpga_reset_status, > }; > > static int socfpga_reset_probe(struct platform_device *pdev) regards Philipp -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/