blob: 48918be649d499b55bfaf762b23d9d7ae0df201e [file] [log] [blame]
Mark Brown48d335b2008-04-30 15:50:21 +01001/*
2 * fixed.h
3 *
4 * Copyright 2008 Wolfson Microelectronics PLC.
5 *
6 * Author: Mark Brown <broonie@opensource.wolfsonmicro.com>
7 *
Roger Quadros86d98842009-08-06 19:37:29 +03008 * Copyright (c) 2009 Nokia Corporation
9 * Roger Quadros <ext-roger.quadros@nokia.com>
10 *
Mark Brown48d335b2008-04-30 15:50:21 +010011 * This program is free software; you can redistribute it and/or
12 * modify it under the terms of the GNU General Public License as
13 * published by the Free Software Foundation; either version 2 of the
14 * License, or (at your option) any later version.
15 */
16
17#ifndef __REGULATOR_FIXED_H
18#define __REGULATOR_FIXED_H
19
Mark Brownbcf34022009-01-19 13:37:04 +000020struct regulator_init_data;
21
Roger Quadros86d98842009-08-06 19:37:29 +030022/**
23 * struct fixed_voltage_config - fixed_voltage_config structure
24 * @supply_name: Name of the regulator supply
Laxman Dewangan6be5bfc2012-07-05 18:12:01 +053025 * @input_supply: Name of the input regulator supply
Roger Quadros86d98842009-08-06 19:37:29 +030026 * @microvolts: Output voltage of regulator
27 * @gpio: GPIO to use for enable control
28 * set to -EINVAL if not used
Adrian Huntereda79a32010-01-12 12:25:13 +020029 * @startup_delay: Start-up time in microseconds
Laxman Dewangana4d9f172012-03-07 15:58:33 +053030 * @gpio_is_open_drain: Gpio pin is open drain or normal type.
31 * If it is open drain type then HIGH will be set
32 * through PULL-UP with setting gpio as input
33 * and low will be set as gpio-output with driven
34 * to low. For non-open-drain case, the gpio will
35 * will be in output and drive to low/high accordingly.
Roger Quadros86d98842009-08-06 19:37:29 +030036 * @enable_high: Polarity of enable GPIO
37 * 1 = Active high, 0 = Active low
38 * @enabled_at_boot: Whether regulator has been enabled at
39 * boot or not. 1 = Yes, 0 = No
40 * This is used to keep the regulator at
41 * the default state
42 * @init_data: regulator_init_data
43 *
44 * This structure contains fixed voltage regulator configuration
45 * information that must be passed by platform code to the fixed
46 * voltage regulator driver.
47 */
Mark Brown48d335b2008-04-30 15:50:21 +010048struct fixed_voltage_config {
49 const char *supply_name;
Laxman Dewangan6be5bfc2012-07-05 18:12:01 +053050 const char *input_supply;
Mark Brown48d335b2008-04-30 15:50:21 +010051 int microvolts;
Roger Quadros86d98842009-08-06 19:37:29 +030052 int gpio;
Adrian Huntereda79a32010-01-12 12:25:13 +020053 unsigned startup_delay;
Laxman Dewangana4d9f172012-03-07 15:58:33 +053054 unsigned gpio_is_open_drain:1;
Roger Quadros86d98842009-08-06 19:37:29 +030055 unsigned enable_high:1;
56 unsigned enabled_at_boot:1;
Mark Brownbcf34022009-01-19 13:37:04 +000057 struct regulator_init_data *init_data;
Mark Brown48d335b2008-04-30 15:50:21 +010058};
59
Sascha Hauer613330a2012-03-03 12:40:02 +010060struct regulator_consumer_supply;
61
62#if IS_ENABLED(CONFIG_REGULATOR)
Guennadi Liakhovetskidfad84a2012-06-19 17:43:56 +020063struct platform_device *regulator_register_always_on(int id, const char *name,
Guennadi Liakhovetski15719cc2012-06-19 17:44:39 +020064 struct regulator_consumer_supply *supplies, int num_supplies, int uv);
Sascha Hauer613330a2012-03-03 12:40:02 +010065#else
Guennadi Liakhovetskidfad84a2012-06-19 17:43:56 +020066static inline struct platform_device *regulator_register_always_on(int id, const char *name,
Guennadi Liakhovetski15719cc2012-06-19 17:44:39 +020067 struct regulator_consumer_supply *supplies, int num_supplies, int uv)
Sascha Hauer613330a2012-03-03 12:40:02 +010068{
69 return NULL;
70}
71#endif
72
Guennadi Liakhovetskidfad84a2012-06-19 17:43:56 +020073#define regulator_register_fixed(id, s, ns) regulator_register_always_on(id, \
Guennadi Liakhovetski15719cc2012-06-19 17:44:39 +020074 "fixed-dummy", s, ns, 0)
Guennadi Liakhovetskidfad84a2012-06-19 17:43:56 +020075
Mark Brown48d335b2008-04-30 15:50:21 +010076#endif