diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2011-11-01 18:06:20 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-11-01 18:06:20 -0400 |
| commit | f3c3f0670501fee130f22193369249deea8cc630 (patch) | |
| tree | 27ae58e4f338d571be93a7557ae7de48de10a947 /include/linux/regulator | |
| parent | c18ae42aa5b3473c00f51b6937d0c00bdb6ce2d2 (diff) | |
| parent | 0151546fb34e92494acd65ed84a603c2a4a90168 (diff) | |
Merge branch 'for-linus' of git://opensource.wolfsonmicro.com/regulator
* 'for-linus' of git://opensource.wolfsonmicro.com/regulator: (22 commits)
regulator: Constify constraints name
regulator: Fix possible nullpointer dereference in regulator_enable()
regulator: gpio-regulator add dependency on GENERIC_GPIO
regulator: Add module.h include to gpio-regulator
regulator: Add driver for gpio-controlled regulators
regulator: remove duplicate REG_CTRL2 defines in tps65023
regulator: Clarify documentation for regulator-regulator supplies
regulator: Fix some bitrot in the machine driver documentation
regulator: tps65023: Added support for the similiar TPS65020 chip
regulator: tps65023: Setting correct core regulator for tps65021
regulator: tps65023: Set missing bit for update core-voltage
regulator: tps65023: Fixes i2c configuration issues
regulator: Add debugfs file showing the supply map table
regulator: tps6586x: add SMx slew rate setting
regulator: tps65023: Fixes i2c configuration issues
regulator: tps6507x: Remove num_voltages array
regulator: max8952: removed unused mutex.
regulator: fix regulator/consumer.h kernel-doc warning
regulator: Ensure enough enable time for max8649
regulator: 88pm8607: Fix off-by-one value range checking in the case of no id is matched
...
Diffstat (limited to 'include/linux/regulator')
| -rw-r--r-- | include/linux/regulator/gpio-regulator.h | 87 | ||||
| -rw-r--r-- | include/linux/regulator/machine.h | 2 |
2 files changed, 88 insertions, 1 deletions
diff --git a/include/linux/regulator/gpio-regulator.h b/include/linux/regulator/gpio-regulator.h new file mode 100644 index 000000000000..19fbd267406d --- /dev/null +++ b/include/linux/regulator/gpio-regulator.h | |||
| @@ -0,0 +1,87 @@ | |||
| 1 | /* | ||
| 2 | * gpio-regulator.h | ||
| 3 | * | ||
| 4 | * Copyright 2011 Heiko Stuebner <heiko@sntech.de> | ||
| 5 | * | ||
| 6 | * based on fixed.h | ||
| 7 | * | ||
| 8 | * Copyright 2008 Wolfson Microelectronics PLC. | ||
| 9 | * | ||
| 10 | * Author: Mark Brown <broonie@opensource.wolfsonmicro.com> | ||
| 11 | * | ||
| 12 | * Copyright (c) 2009 Nokia Corporation | ||
| 13 | * Roger Quadros <ext-roger.quadros@nokia.com> | ||
| 14 | * | ||
| 15 | * This program is free software; you can redistribute it and/or | ||
| 16 | * modify it under the terms of the GNU General Public License as | ||
| 17 | * published by the Free Software Foundation; either version 2 of the | ||
| 18 | * License, or (at your option) any later version. | ||
| 19 | */ | ||
| 20 | |||
| 21 | #ifndef __REGULATOR_GPIO_H | ||
| 22 | #define __REGULATOR_GPIO_H | ||
| 23 | |||
| 24 | struct regulator_init_data; | ||
| 25 | |||
| 26 | enum regulator_type; | ||
| 27 | |||
| 28 | /** | ||
| 29 | * struct gpio_regulator_state - state description | ||
| 30 | * @value: microvolts or microamps | ||
| 31 | * @gpios: bitfield of gpio target-states for the value | ||
| 32 | * | ||
| 33 | * This structure describes a supported setting of the regulator | ||
| 34 | * and the necessary gpio-state to achieve it. | ||
| 35 | * | ||
| 36 | * The n-th bit in the bitfield describes the state of the n-th GPIO | ||
| 37 | * from the gpios-array defined in gpio_regulator_config below. | ||
| 38 | */ | ||
| 39 | struct gpio_regulator_state { | ||
| 40 | int value; | ||
| 41 | int gpios; | ||
| 42 | }; | ||
| 43 | |||
| 44 | /** | ||
| 45 | * struct gpio_regulator_config - config structure | ||
| 46 | * @supply_name: Name of the regulator supply | ||
| 47 | * @enable_gpio: GPIO to use for enable control | ||
| 48 | * set to -EINVAL if not used | ||
| 49 | * @enable_high: Polarity of enable GPIO | ||
| 50 | * 1 = Active high, 0 = Active low | ||
| 51 | * @enabled_at_boot: Whether regulator has been enabled at | ||
| 52 | * boot or not. 1 = Yes, 0 = No | ||
| 53 | * This is used to keep the regulator at | ||
| 54 | * the default state | ||
| 55 | * @startup_delay: Start-up time in microseconds | ||
| 56 | * @gpios: Array containing the gpios needed to control | ||
| 57 | * the setting of the regulator | ||
| 58 | * @nr_gpios: Number of gpios | ||
| 59 | * @states: Array of gpio_regulator_state entries describing | ||
| 60 | * the gpio state for specific voltages | ||
| 61 | * @nr_states: Number of states available | ||
| 62 | * @regulator_type: either REGULATOR_CURRENT or REGULATOR_VOLTAGE | ||
| 63 | * @init_data: regulator_init_data | ||
| 64 | * | ||
| 65 | * This structure contains gpio-voltage regulator configuration | ||
| 66 | * information that must be passed by platform code to the | ||
| 67 | * gpio-voltage regulator driver. | ||
| 68 | */ | ||
| 69 | struct gpio_regulator_config { | ||
| 70 | const char *supply_name; | ||
| 71 | |||
| 72 | int enable_gpio; | ||
| 73 | unsigned enable_high:1; | ||
| 74 | unsigned enabled_at_boot:1; | ||
| 75 | unsigned startup_delay; | ||
| 76 | |||
| 77 | struct gpio *gpios; | ||
| 78 | int nr_gpios; | ||
| 79 | |||
| 80 | struct gpio_regulator_state *states; | ||
| 81 | int nr_states; | ||
| 82 | |||
| 83 | enum regulator_type type; | ||
| 84 | struct regulator_init_data *init_data; | ||
| 85 | }; | ||
| 86 | |||
| 87 | #endif | ||
diff --git a/include/linux/regulator/machine.h b/include/linux/regulator/machine.h index ce3127a75c88..f3f13fd5868f 100644 --- a/include/linux/regulator/machine.h +++ b/include/linux/regulator/machine.h | |||
| @@ -95,7 +95,7 @@ struct regulator_state { | |||
| 95 | */ | 95 | */ |
| 96 | struct regulation_constraints { | 96 | struct regulation_constraints { |
| 97 | 97 | ||
| 98 | char *name; | 98 | const char *name; |
| 99 | 99 | ||
| 100 | /* voltage output range (inclusive) - for voltage control */ | 100 | /* voltage output range (inclusive) - for voltage control */ |
| 101 | int min_uV; | 101 | int min_uV; |
