From patchwork Wed Mar 11 12:22:26 2009 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: David Brownell X-Patchwork-Id: 11119 Received: from vger.kernel.org (vger.kernel.org [209.132.176.167]) by demeter.kernel.org (8.14.2/8.14.2) with ESMTP id n2BCWqGh024749 for ; Wed, 11 Mar 2009 12:32:53 GMT Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752648AbZCKMcv (ORCPT ); Wed, 11 Mar 2009 08:32:51 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1752371AbZCKMcv (ORCPT ); Wed, 11 Mar 2009 08:32:51 -0400 Received: from smtp120.sbc.mail.sp1.yahoo.com ([69.147.64.93]:44247 "HELO smtp120.sbc.mail.sp1.yahoo.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with SMTP id S1752348AbZCKMcu (ORCPT ); Wed, 11 Mar 2009 08:32:50 -0400 Received: (qmail 93383 invoked from network); 11 Mar 2009 12:32:48 -0000 DomainKey-Signature: a=rsa-sha1; q=dns; c=nofws; s=s1024; d=pacbell.net; h=Received:X-YMail-OSG:X-Yahoo-Newman-Property:From:To:Subject:Date:User-Agent:References:In-Reply-To:MIME-Version:Content-Type:Content-Transfer-Encoding:Content-Disposition:Message-Id; b=HpU3uww+ByovidEgiM6eYLhOv0gxlFcY8fn6U7rL1a+yvOl2gZ1/5UJhyyjBLakSKT9JdjD/z7/mZX/lvSsM/BhDjF3YkY4eV7w8Ui/gsY6SO2nYh6fclLJgx0LCff3cxPJubBjEDL8PedJqSJlBu78Kf2IjRDFab3VED/L1haE= ; Received: from unknown (HELO pogo) (david-b@69.226.224.20 with plain) by smtp120.sbc.mail.sp1.yahoo.com with SMTP; 11 Mar 2009 12:32:48 -0000 X-YMail-OSG: yb9VVdkVM1kx8wILZHcrGSfeJ3aXNlo6flAkiujJB8wSX2gfKFuPyJC291cgowEkRQgdKxJjHmSh_nTEyS8dI0Gv6BOdnLjPAY6YQSrmyovugwtn32xlcNOdAlSYQDTMzFjUa627m.oeOpFO6uva8UfYMsCrNO.Agi90v5dO.L7IVY6vXnr_bGlKm8EUIU4s9kVkr4fGR6rJwfuxBl60EgZuM4t4I8XptkMo.w-- X-Yahoo-Newman-Property: ymail-3 From: David Brownell To: OMAP Subject: [patch 2.6.29-rc7-omap 3/5] regulator: twl4030 voltage enumeration cleanup Date: Wed, 11 Mar 2009 04:22:26 -0800 User-Agent: KMail/1.9.10 References: <200903110518.34945.david-b@pacbell.net> In-Reply-To: <200903110518.34945.david-b@pacbell.net> MIME-Version: 1.0 Content-Disposition: inline Message-Id: <200903110522.26844.david-b@pacbell.net> Sender: linux-omap-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-omap@vger.kernel.org From: David Brownell Subject: regulator: twl4030 voltage enumeration (v2) cleanups Minor cleanups to the twl403 regulator driver, mostly enabled by other recent changes: comments, shrink memory usage, add definition for one bit. Signed-off-by: David Brownell Signed-off-by: Liam Girdwood --- drivers/regulator/twl4030-regulator.c | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) -- To unsubscribe from this list: send the line "unsubscribe linux-omap" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html --- a/drivers/regulator/twl4030-regulator.c +++ b/drivers/regulator/twl4030-regulator.c @@ -36,13 +36,13 @@ struct twlreg_info { /* twl4030 resource ID, for resource control state machine */ u8 id; + /* FIXED_LDO voltage */ + u8 deciV; + /* voltage in mV = table[VSEL]; table_len must be a power-of-two */ u8 table_len; const u16 *table; - /* chip constraints on regulator behavior */ - u16 min_mV; - /* used by regulator core */ struct regulator_desc desc; }; @@ -97,6 +97,7 @@ static int twl4030reg_grp(struct regulat #define P3_GRP BIT(7) /* "peripherals" */ #define P2_GRP BIT(6) /* secondary processor, modem, etc */ #define P1_GRP BIT(5) /* CPU/Linux */ +#define WARM_CFG BIT(4) static int twl4030reg_is_enabled(struct regulator_dev *rdev) { @@ -329,14 +330,14 @@ static int twl4030fixed_list_voltage(str { struct twlreg_info *info = rdev_get_drvdata(rdev); - return info->min_mV * 1000; + return info->deciV * 100 * 1000; } static int twl4030fixed_get_voltage(struct regulator_dev *rdev) { struct twlreg_info *info = rdev_get_drvdata(rdev); - return info->min_mV * 1000; + return info->deciV * 100 * 1000; } static struct regulator_ops twl4030fixed_ops = { @@ -373,7 +374,7 @@ static struct regulator_ops twl4030fixed #define TWL_FIXED_LDO(label, offset, mVolts, num) { \ .base = offset, \ .id = num, \ - .min_mV = mVolts, \ + .deciV = mVolts / 100 , \ .desc = { \ .name = #label, \ .id = TWL4030_REG_##label, \ @@ -385,7 +386,7 @@ static struct regulator_ops twl4030fixed } /* - * We list regulators here if systems need some level of + * We expose regulators here if systems need some level of * software control over them after boot. */ static struct twlreg_info twl4030_regs[] = { @@ -439,6 +440,7 @@ static int twl4030reg_probe(struct platf /* Constrain board-specific capabilities according to what * this driver and the chip itself can actually do. + * (Regulator core now does this for voltage constraints.) */ c = &initdata->constraints; c->valid_modes_mask &= REGULATOR_MODE_NORMAL | REGULATOR_MODE_STANDBY;