diff options
Diffstat (limited to 'drivers/regulator/fixed.c')
| -rw-r--r-- | drivers/regulator/fixed.c | 30 |
1 files changed, 21 insertions, 9 deletions
diff --git a/drivers/regulator/fixed.c b/drivers/regulator/fixed.c index f9f516a3028a..d11f7622430b 100644 --- a/drivers/regulator/fixed.c +++ b/drivers/regulator/fixed.c | |||
| @@ -24,14 +24,16 @@ | |||
| 24 | #include <linux/regulator/driver.h> | 24 | #include <linux/regulator/driver.h> |
| 25 | #include <linux/regulator/fixed.h> | 25 | #include <linux/regulator/fixed.h> |
| 26 | #include <linux/gpio.h> | 26 | #include <linux/gpio.h> |
| 27 | #include <linux/delay.h> | ||
| 27 | 28 | ||
| 28 | struct fixed_voltage_data { | 29 | struct fixed_voltage_data { |
| 29 | struct regulator_desc desc; | 30 | struct regulator_desc desc; |
| 30 | struct regulator_dev *dev; | 31 | struct regulator_dev *dev; |
| 31 | int microvolts; | 32 | int microvolts; |
| 32 | int gpio; | 33 | int gpio; |
| 33 | unsigned enable_high:1; | 34 | unsigned startup_delay; |
| 34 | unsigned is_enabled:1; | 35 | bool enable_high; |
| 36 | bool is_enabled; | ||
| 35 | }; | 37 | }; |
| 36 | 38 | ||
| 37 | static int fixed_voltage_is_enabled(struct regulator_dev *dev) | 39 | static int fixed_voltage_is_enabled(struct regulator_dev *dev) |
| @@ -47,7 +49,7 @@ static int fixed_voltage_enable(struct regulator_dev *dev) | |||
| 47 | 49 | ||
| 48 | if (gpio_is_valid(data->gpio)) { | 50 | if (gpio_is_valid(data->gpio)) { |
| 49 | gpio_set_value_cansleep(data->gpio, data->enable_high); | 51 | gpio_set_value_cansleep(data->gpio, data->enable_high); |
| 50 | data->is_enabled = 1; | 52 | data->is_enabled = true; |
| 51 | } | 53 | } |
| 52 | 54 | ||
| 53 | return 0; | 55 | return 0; |
| @@ -59,12 +61,19 @@ static int fixed_voltage_disable(struct regulator_dev *dev) | |||
| 59 | 61 | ||
| 60 | if (gpio_is_valid(data->gpio)) { | 62 | if (gpio_is_valid(data->gpio)) { |
| 61 | gpio_set_value_cansleep(data->gpio, !data->enable_high); | 63 | gpio_set_value_cansleep(data->gpio, !data->enable_high); |
| 62 | data->is_enabled = 0; | 64 | data->is_enabled = false; |
| 63 | } | 65 | } |
| 64 | 66 | ||
| 65 | return 0; | 67 | return 0; |
| 66 | } | 68 | } |
| 67 | 69 | ||
| 70 | static int fixed_voltage_enable_time(struct regulator_dev *dev) | ||
| 71 | { | ||
| 72 | struct fixed_voltage_data *data = rdev_get_drvdata(dev); | ||
| 73 | |||
| 74 | return data->startup_delay; | ||
| 75 | } | ||
| 76 | |||
| 68 | static int fixed_voltage_get_voltage(struct regulator_dev *dev) | 77 | static int fixed_voltage_get_voltage(struct regulator_dev *dev) |
| 69 | { | 78 | { |
| 70 | struct fixed_voltage_data *data = rdev_get_drvdata(dev); | 79 | struct fixed_voltage_data *data = rdev_get_drvdata(dev); |
| @@ -87,11 +96,12 @@ static struct regulator_ops fixed_voltage_ops = { | |||
| 87 | .is_enabled = fixed_voltage_is_enabled, | 96 | .is_enabled = fixed_voltage_is_enabled, |
| 88 | .enable = fixed_voltage_enable, | 97 | .enable = fixed_voltage_enable, |
| 89 | .disable = fixed_voltage_disable, | 98 | .disable = fixed_voltage_disable, |
| 99 | .enable_time = fixed_voltage_enable_time, | ||
| 90 | .get_voltage = fixed_voltage_get_voltage, | 100 | .get_voltage = fixed_voltage_get_voltage, |
| 91 | .list_voltage = fixed_voltage_list_voltage, | 101 | .list_voltage = fixed_voltage_list_voltage, |
| 92 | }; | 102 | }; |
| 93 | 103 | ||
| 94 | static int regulator_fixed_voltage_probe(struct platform_device *pdev) | 104 | static int __devinit reg_fixed_voltage_probe(struct platform_device *pdev) |
| 95 | { | 105 | { |
| 96 | struct fixed_voltage_config *config = pdev->dev.platform_data; | 106 | struct fixed_voltage_config *config = pdev->dev.platform_data; |
| 97 | struct fixed_voltage_data *drvdata; | 107 | struct fixed_voltage_data *drvdata; |
| @@ -117,6 +127,7 @@ static int regulator_fixed_voltage_probe(struct platform_device *pdev) | |||
| 117 | 127 | ||
| 118 | drvdata->microvolts = config->microvolts; | 128 | drvdata->microvolts = config->microvolts; |
| 119 | drvdata->gpio = config->gpio; | 129 | drvdata->gpio = config->gpio; |
| 130 | drvdata->startup_delay = config->startup_delay; | ||
| 120 | 131 | ||
| 121 | if (gpio_is_valid(config->gpio)) { | 132 | if (gpio_is_valid(config->gpio)) { |
| 122 | drvdata->enable_high = config->enable_high; | 133 | drvdata->enable_high = config->enable_high; |
| @@ -163,7 +174,7 @@ static int regulator_fixed_voltage_probe(struct platform_device *pdev) | |||
| 163 | /* Regulator without GPIO control is considered | 174 | /* Regulator without GPIO control is considered |
| 164 | * always enabled | 175 | * always enabled |
| 165 | */ | 176 | */ |
| 166 | drvdata->is_enabled = 1; | 177 | drvdata->is_enabled = true; |
| 167 | } | 178 | } |
| 168 | 179 | ||
| 169 | drvdata->dev = regulator_register(&drvdata->desc, &pdev->dev, | 180 | drvdata->dev = regulator_register(&drvdata->desc, &pdev->dev, |
| @@ -191,7 +202,7 @@ err: | |||
| 191 | return ret; | 202 | return ret; |
| 192 | } | 203 | } |
| 193 | 204 | ||
| 194 | static int regulator_fixed_voltage_remove(struct platform_device *pdev) | 205 | static int __devexit reg_fixed_voltage_remove(struct platform_device *pdev) |
| 195 | { | 206 | { |
| 196 | struct fixed_voltage_data *drvdata = platform_get_drvdata(pdev); | 207 | struct fixed_voltage_data *drvdata = platform_get_drvdata(pdev); |
| 197 | 208 | ||
| @@ -205,10 +216,11 @@ static int regulator_fixed_voltage_remove(struct platform_device *pdev) | |||
| 205 | } | 216 | } |
| 206 | 217 | ||
| 207 | static struct platform_driver regulator_fixed_voltage_driver = { | 218 | static struct platform_driver regulator_fixed_voltage_driver = { |
| 208 | .probe = regulator_fixed_voltage_probe, | 219 | .probe = reg_fixed_voltage_probe, |
| 209 | .remove = regulator_fixed_voltage_remove, | 220 | .remove = __devexit_p(reg_fixed_voltage_remove), |
| 210 | .driver = { | 221 | .driver = { |
| 211 | .name = "reg-fixed-voltage", | 222 | .name = "reg-fixed-voltage", |
| 223 | .owner = THIS_MODULE, | ||
| 212 | }, | 224 | }, |
| 213 | }; | 225 | }; |
| 214 | 226 | ||
