mirror of
https://git.proxmox.com/git/mirror_ubuntu-kernels.git
synced 2025-11-25 16:33:36 +00:00
As we augmented the regulator core to accept a GPIO descriptor instead
of a GPIO number, we can augment the fixed GPIO regulator to look up
and pass that descriptor directly from device tree or board GPIO
descriptor look up tables.
Some boards just auto-enumerate their fixed regulator platform devices
and I have assumed they get names like "fixed-regulator.0" but it's
pretty hard to guess this. I need some testing from board maintainers to
be sure. Other boards are straight forward, using just plain
"fixed-regulator" (ID -1) or "fixed-regulator.1" hammering down the
device ID.
The OMAP didn't have proper label names on its GPIO chips so I have fixed
this with a separate patch to the GPIO tree, see
commit 088413bc0b
"gpio: omap: Give unique labels to each GPIO bank/chip"
It seems the da9055 and da9211 has never got around to actually passing
any enable gpio into its platform data (not the in-tree code anyway) so we
can just decide to simply pass a descriptor instead.
The fixed GPIO-controlled regulator in mach-pxa/ezx.c was confusingly named
"*_dummy_supply_device" while it is a very real device backed by a GPIO
line. There is nothing dummy about it at all, so I renamed it with the
infix *_regulator_* as part of this patch set.
For the patch hunk hitting arch/blackfin I would say I do not expect
testing, review or ACKs anymore so if it works, it works.
The hunk hitting the x86 BCM43xx driver is especially tricky as the number
comes out of SFI which is a mystery to me. I definately need someone to
look at this. (Hi Andy.)
Cc: Andy Shevchenko <andriy.shevchenko@linux.intel.com> # Check the x86 BCM stuff
Cc: Alexander Shiyan <shc_work@mail.ru> # i.MX boards user
Cc: Haojian Zhuang <haojian.zhuang@gmail.com> # MMP2 maintainer
Cc: Aaro Koskinen <aaro.koskinen@iki.fi> # OMAP1 maintainer
Cc: Tony Lindgren <tony@atomide.com> # OMAP1,2,3 maintainer
Cc: Mike Rapoport <rppt@linux.vnet.ibm.com> # EM-X270 maintainer
Cc: Robert Jarzmik <robert.jarzmik@free.fr> # EZX maintainer
Cc: Philipp Zabel <philipp.zabel@gmail.com> # Magician maintainer
Cc: Daniel Mack <zonque@gmail.com> # Raumfeld maintainer
Cc: Marc Zyngier <marc.zyngier@arm.com> # Zeus maintainer
Cc: Geert Uytterhoeven <geert+renesas@glider.be> # SuperH pinctrl/GPIO maintainer
Cc: Russell King <rmk+kernel@armlinux.org.uk> # SA1100
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Acked-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Acked-by: Tony Lindgren <tony@atomide.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
74 lines
2.3 KiB
C
74 lines
2.3 KiB
C
/*
|
|
* fixed.h
|
|
*
|
|
* Copyright 2008 Wolfson Microelectronics PLC.
|
|
*
|
|
* Author: Mark Brown <broonie@opensource.wolfsonmicro.com>
|
|
*
|
|
* Copyright (c) 2009 Nokia Corporation
|
|
* Roger Quadros <ext-roger.quadros@nokia.com>
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License as
|
|
* published by the Free Software Foundation; either version 2 of the
|
|
* License, or (at your option) any later version.
|
|
*/
|
|
|
|
#ifndef __REGULATOR_FIXED_H
|
|
#define __REGULATOR_FIXED_H
|
|
|
|
struct regulator_init_data;
|
|
|
|
/**
|
|
* struct fixed_voltage_config - fixed_voltage_config structure
|
|
* @supply_name: Name of the regulator supply
|
|
* @input_supply: Name of the input regulator supply
|
|
* @microvolts: Output voltage of regulator
|
|
* @startup_delay: Start-up time in microseconds
|
|
* @gpio_is_open_drain: Gpio pin is open drain or normal type.
|
|
* If it is open drain type then HIGH will be set
|
|
* through PULL-UP with setting gpio as input
|
|
* and low will be set as gpio-output with driven
|
|
* to low. For non-open-drain case, the gpio will
|
|
* will be in output and drive to low/high accordingly.
|
|
* @enable_high: Polarity of enable GPIO
|
|
* 1 = Active high, 0 = Active low
|
|
* @enabled_at_boot: Whether regulator has been enabled at
|
|
* boot or not. 1 = Yes, 0 = No
|
|
* This is used to keep the regulator at
|
|
* the default state
|
|
* @init_data: regulator_init_data
|
|
*
|
|
* This structure contains fixed voltage regulator configuration
|
|
* information that must be passed by platform code to the fixed
|
|
* voltage regulator driver.
|
|
*/
|
|
struct fixed_voltage_config {
|
|
const char *supply_name;
|
|
const char *input_supply;
|
|
int microvolts;
|
|
unsigned startup_delay;
|
|
unsigned gpio_is_open_drain:1;
|
|
unsigned enable_high:1;
|
|
unsigned enabled_at_boot:1;
|
|
struct regulator_init_data *init_data;
|
|
};
|
|
|
|
struct regulator_consumer_supply;
|
|
|
|
#if IS_ENABLED(CONFIG_REGULATOR)
|
|
struct platform_device *regulator_register_always_on(int id, const char *name,
|
|
struct regulator_consumer_supply *supplies, int num_supplies, int uv);
|
|
#else
|
|
static inline struct platform_device *regulator_register_always_on(int id, const char *name,
|
|
struct regulator_consumer_supply *supplies, int num_supplies, int uv)
|
|
{
|
|
return NULL;
|
|
}
|
|
#endif
|
|
|
|
#define regulator_register_fixed(id, s, ns) regulator_register_always_on(id, \
|
|
"fixed-dummy", s, ns, 0)
|
|
|
|
#endif
|