mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-01 02:33:57 +00:00
2874c5fd28
Based on 1 normalized pattern(s): 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 extracted by the scancode license scanner the SPDX license identifier GPL-2.0-or-later has been chosen to replace the boilerplate/reference in 3029 file(s). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Allison Randal <allison@lohutok.net> Cc: linux-spdx@vger.kernel.org Link: https://lkml.kernel.org/r/20190527070032.746973796@linutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
92 lines
2.5 KiB
C
92 lines
2.5 KiB
C
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
/* NXP PCF50633 GPIO Driver
|
|
*
|
|
* (C) 2006-2008 by Openmoko, Inc.
|
|
* Author: Balaji Rao <balajirrao@openmoko.org>
|
|
* All rights reserved.
|
|
*
|
|
* Broken down from monstrous PCF50633 driver mainly by
|
|
* Harald Welte, Andy Green and Werner Almesberger
|
|
*/
|
|
|
|
#include <linux/kernel.h>
|
|
#include <linux/module.h>
|
|
|
|
#include <linux/mfd/pcf50633/core.h>
|
|
#include <linux/mfd/pcf50633/gpio.h>
|
|
#include <linux/mfd/pcf50633/pmic.h>
|
|
|
|
static const u8 pcf50633_regulator_registers[PCF50633_NUM_REGULATORS] = {
|
|
[PCF50633_REGULATOR_AUTO] = PCF50633_REG_AUTOOUT,
|
|
[PCF50633_REGULATOR_DOWN1] = PCF50633_REG_DOWN1OUT,
|
|
[PCF50633_REGULATOR_DOWN2] = PCF50633_REG_DOWN2OUT,
|
|
[PCF50633_REGULATOR_MEMLDO] = PCF50633_REG_MEMLDOOUT,
|
|
[PCF50633_REGULATOR_LDO1] = PCF50633_REG_LDO1OUT,
|
|
[PCF50633_REGULATOR_LDO2] = PCF50633_REG_LDO2OUT,
|
|
[PCF50633_REGULATOR_LDO3] = PCF50633_REG_LDO3OUT,
|
|
[PCF50633_REGULATOR_LDO4] = PCF50633_REG_LDO4OUT,
|
|
[PCF50633_REGULATOR_LDO5] = PCF50633_REG_LDO5OUT,
|
|
[PCF50633_REGULATOR_LDO6] = PCF50633_REG_LDO6OUT,
|
|
[PCF50633_REGULATOR_HCLDO] = PCF50633_REG_HCLDOOUT,
|
|
};
|
|
|
|
int pcf50633_gpio_set(struct pcf50633 *pcf, int gpio, u8 val)
|
|
{
|
|
u8 reg;
|
|
|
|
reg = gpio - PCF50633_GPIO1 + PCF50633_REG_GPIO1CFG;
|
|
|
|
return pcf50633_reg_set_bit_mask(pcf, reg, 0x07, val);
|
|
}
|
|
EXPORT_SYMBOL_GPL(pcf50633_gpio_set);
|
|
|
|
u8 pcf50633_gpio_get(struct pcf50633 *pcf, int gpio)
|
|
{
|
|
u8 reg, val;
|
|
|
|
reg = gpio - PCF50633_GPIO1 + PCF50633_REG_GPIO1CFG;
|
|
val = pcf50633_reg_read(pcf, reg) & 0x07;
|
|
|
|
return val;
|
|
}
|
|
EXPORT_SYMBOL_GPL(pcf50633_gpio_get);
|
|
|
|
int pcf50633_gpio_invert_set(struct pcf50633 *pcf, int gpio, int invert)
|
|
{
|
|
u8 val, reg;
|
|
|
|
reg = gpio - PCF50633_GPIO1 + PCF50633_REG_GPIO1CFG;
|
|
val = !!invert << 3;
|
|
|
|
return pcf50633_reg_set_bit_mask(pcf, reg, 1 << 3, val);
|
|
}
|
|
EXPORT_SYMBOL_GPL(pcf50633_gpio_invert_set);
|
|
|
|
int pcf50633_gpio_invert_get(struct pcf50633 *pcf, int gpio)
|
|
{
|
|
u8 reg, val;
|
|
|
|
reg = gpio - PCF50633_GPIO1 + PCF50633_REG_GPIO1CFG;
|
|
val = pcf50633_reg_read(pcf, reg);
|
|
|
|
return val & (1 << 3);
|
|
}
|
|
EXPORT_SYMBOL_GPL(pcf50633_gpio_invert_get);
|
|
|
|
int pcf50633_gpio_power_supply_set(struct pcf50633 *pcf,
|
|
int gpio, int regulator, int on)
|
|
{
|
|
u8 reg, val, mask;
|
|
|
|
/* the *ENA register is always one after the *OUT register */
|
|
reg = pcf50633_regulator_registers[regulator] + 1;
|
|
|
|
val = !!on << (gpio - PCF50633_GPIO1);
|
|
mask = 1 << (gpio - PCF50633_GPIO1);
|
|
|
|
return pcf50633_reg_set_bit_mask(pcf, reg, mask, val);
|
|
}
|
|
EXPORT_SYMBOL_GPL(pcf50633_gpio_power_supply_set);
|
|
|
|
MODULE_LICENSE("GPL");
|