[PATCH 03/13] [ARM] pxa/palm: Add core pmic support for Palm27x
Eric Miao
eric.y.miao at gmail.com
Tue Aug 3 23:16:14 EDT 2010
On Thu, Jul 29, 2010 at 6:03 PM, Mike Rapoport <mike at compulab.co.il> wrote:
> Marek Vasut wrote:
>>
>> Signed-off-by: Marek Vasut <marek.vasut at gmail.com>
>> ---
>> arch/arm/mach-pxa/palm27x.c | 57
>> +++++++++++++++++++++++++++++++++++++++++++
>> 1 files changed, 57 insertions(+), 0 deletions(-)
>>
>> diff --git a/arch/arm/mach-pxa/palm27x.c b/arch/arm/mach-pxa/palm27x.c
>> index ff5ee8c..a1009ec 100644
>> --- a/arch/arm/mach-pxa/palm27x.c
>> +++ b/arch/arm/mach-pxa/palm27x.c
>> @@ -21,6 +21,7 @@
>> #include <linux/wm97xx.h>
>> #include <linux/power_supply.h>
>> #include <linux/usb/gpio_vbus.h>
>> +#include <linux/regulator/max1586.h>
>> #include <asm/mach-types.h>
>> #include <asm/mach/arch.h>
>> @@ -35,6 +36,8 @@
>> #include <mach/palmasoc.h>
>> #include <mach/palm27x.h>
>> +#include <plat/i2c.h>
>> +
>> #include "generic.h"
>> #include "devices.h"
>> @@ -458,6 +461,59 @@ static void __init palm27x_power_init(int ac, int
>> usb)
>> static inline void palm27x_power_init(int ac, int usb) {}
>> #endif
>>
>> +/******************************************************************************
>> + * Core power regulator
>> +
>> ******************************************************************************/
>> +#if defined(CONFIG_REGULATOR_MAX1586) || \
>> + defined(CONFIG_REGULATOR_MAX1586_MODULE)
>> +static struct regulator_consumer_supply palm27x_max1587a_consumers[] = {
>> + {
>> + .supply = "vcc_core",
>> + }
>> +};
>> +
>> +static struct regulator_init_data palm27x_max1587a_v3_info = {
>> + .constraints = {
>> + .name = "vcc_core range",
>> + .min_uV = 900000,
>> + .max_uV = 1705000,
>> + .always_on = 1,
>> + .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE,
>> + },
>> + .consumer_supplies = palm27x_max1587a_consumers,
>> + .num_consumer_supplies = ARRAY_SIZE(palm27x_max1587a_consumers),
>> +};
>> +
>> +static struct max1586_subdev_data palm27x_max1587a_subdevs[] = {
>> + {
>> + .name = "vcc_core",
>> + .id = MAX1586_V3,
>> + .platform_data = &palm27x_max1587a_v3_info,
>> + }
>> +};
>> +
>> +static struct max1586_platform_data palm27x_max1587a_info = {
>> + .subdevs = palm27x_max1587a_subdevs,
>> + .num_subdevs = ARRAY_SIZE(palm27x_max1587a_subdevs),
>> + .v3_gain = MAX1586_GAIN_R24_3k32, /* 730..1550 mV */
>> +};
>> +
>> +static struct i2c_board_info __initdata palm27x_pi2c_board_info[] = {
>> + {
>> + I2C_BOARD_INFO("max1586", 0x14),
>> + .platform_data = &palm27x_max1587a_info,
>> + },
>> +};
>> +
>> +static void __init palm27x_pmic_init(void)
>> +{
>> + i2c_register_board_info(1,
>> ARRAY_AND_SIZE(palm27x_pi2c_board_info));
>> + pxa27x_set_i2c_power_info(NULL);
>
> Consider using PIO mode for PMIC communications
>
Yep, otherwise looks good to me.
>> +}
>> +#else
>> +static inline void palm27x_pmic_init(void) {}
>> +#endif
>> +
>> void __init palm27x_common_init(struct palm27x_handheld *palm)
>> {
>> pxa_set_ffuart_info(NULL);
>> @@ -472,4 +528,5 @@ void __init palm27x_common_init(struct
>> palm27x_handheld *palm)
>> palm27x_ac97_init(palm->batt_minv, palm->batt_maxv,
>> palm->jack_gpio);
>> palm27x_pwm_init(palm->bl_bl, palm->bl_lcd);
>> palm27x_power_init(palm->power_ac, palm->power_usb);
>> + palm27x_pmic_init();
>> }
>
>
> --
> Sincerely yours,
> Mike.
>
More information about the linux-arm-kernel
mailing list