2024-09-09 08:57:42 +00:00

227 lines
8.0 KiB
C

/* Copyright (c) 2012, 2015, The Linux Foundation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 and
* only version 2 as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*/
/* Mode select */
#define QPNP_PIN_MODE_DIG_IN 0
#define QPNP_PIN_MODE_DIG_OUT 1
#define QPNP_PIN_MODE_DIG_IN_OUT 2
#define QPNP_PIN_MODE_ANA_PASS_THRU 3
#define QPNP_PIN_MODE_BIDIR 3
#define QPNP_PIN_MODE_AIN 4
#define QPNP_PIN_MODE_AOUT 5
#define QPNP_PIN_MODE_SINK 6
/* Invert source select (GPIO, MPP) */
#define QPNP_PIN_INVERT_DISABLE 0
#define QPNP_PIN_INVERT_ENABLE 1
/* Output type (GPIO) */
#define QPNP_PIN_OUT_BUF_CMOS 0
#define QPNP_PIN_OUT_BUF_OPEN_DRAIN_NMOS 1
#define QPNP_PIN_OUT_BUF_OPEN_DRAIN_PMOS 2
#define QPNP_PIN_OUT_BUF_NO_DRIVE 3
/* Voltage select (GPIO, MPP) */
#define QPNP_PIN_VIN0 0
#define QPNP_PIN_VIN1 1
#define QPNP_PIN_VIN2 2
#define QPNP_PIN_VIN3 3
#define QPNP_PIN_VIN4 4
#define QPNP_PIN_VIN5 5
#define QPNP_PIN_VIN6 6
#define QPNP_PIN_VIN7 7
/* Pull Up Values (GPIO) */
#define QPNP_PIN_GPIO_PULL_UP_30 0
#define QPNP_PIN_GPIO_PULL_UP_1P5 1
#define QPNP_PIN_GPIO_PULL_UP_31P5 2
#define QPNP_PIN_GPIO_PULL_UP_1P5_30 3
#define QPNP_PIN_GPIO_PULL_DN 4
#define QPNP_PIN_GPIO_PULL_NO 5
/* Pull Up Values (MPP) */
#define QPNP_PIN_MPP_PULL_UP_0P6KOHM 0
#define QPNP_PIN_MPP_PULL_UP_OPEN 1
#define QPNP_PIN_MPP_PULL_UP_10KOHM 2
#define QPNP_PIN_MPP_PULL_UP_30KOHM 3
/* Out Strength (GPIO) */
#define QPNP_PIN_OUT_STRENGTH_LOW 1
#define QPNP_PIN_OUT_STRENGTH_MED 2
#define QPNP_PIN_OUT_STRENGTH_HIGH 3
/* Digital-in CTL (GPIO/MPP) */
#define QPNP_PIN_DIG_IN_CTL_DTEST1 1
#define QPNP_PIN_DIG_IN_CTL_DTEST2 2
#define QPNP_PIN_DIG_IN_CTL_DTEST3 3
#define QPNP_PIN_DIG_IN_CTL_DTEST4 4
/* Source Select (GPIO) / Enable Select (MPP) */
#define QPNP_PIN_SEL_FUNC_CONSTANT 0
#define QPNP_PIN_SEL_FUNC_PAIRED 1
#define QPNP_PIN_SEL_FUNC_1 2
#define QPNP_PIN_SEL_FUNC_2 3
#define QPNP_PIN_SEL_DTEST1 4
#define QPNP_PIN_SEL_DTEST2 5
#define QPNP_PIN_SEL_DTEST3 6
#define QPNP_PIN_SEL_DTEST4 7
/* Source Select for GPIO_LV/GPIO_MV only */
#define QPNP_PIN_LV_MV_SEL_FUNC_CONSTANT 0
#define QPNP_PIN_LV_MV_SEL_FUNC_PAIRED 1
#define QPNP_PIN_LV_MV_SEL_FUNC_1 2
#define QPNP_PIN_LV_MV_SEL_FUNC_2 3
#define QPNP_PIN_LV_MV_SEL_FUNC_3 4
#define QPNP_PIN_LV_MV_SEL_FUNC_4 5
#define QPNP_PIN_LV_MV_SEL_DTEST1 6
#define QPNP_PIN_LV_MV_SEL_DTEST2 7
#define QPNP_PIN_LV_MV_SEL_DTEST3 8
#define QPNP_PIN_LV_MV_SEL_DTEST4 9
/* Master enable (GPIO, MPP) */
#define QPNP_PIN_MASTER_DISABLE 0
#define QPNP_PIN_MASTER_ENABLE 1
/* Analog Output (MPP) */
#define QPNP_PIN_AOUT_1V25 0
#define QPNP_PIN_AOUT_0V625 1
#define QPNP_PIN_AOUT_0V3125 2
#define QPNP_PIN_AOUT_MPP 3
#define QPNP_PIN_AOUT_ABUS1 4
#define QPNP_PIN_AOUT_ABUS2 5
#define QPNP_PIN_AOUT_ABUS3 6
#define QPNP_PIN_AOUT_ABUS4 7
/* Analog Input (MPP) */
#define QPNP_PIN_AIN_AMUX_CH5 0
#define QPNP_PIN_AIN_AMUX_CH6 1
#define QPNP_PIN_AIN_AMUX_CH7 2
#define QPNP_PIN_AIN_AMUX_CH8 3
#define QPNP_PIN_AIN_AMUX_ABUS1 4
#define QPNP_PIN_AIN_AMUX_ABUS2 5
#define QPNP_PIN_AIN_AMUX_ABUS3 6
#define QPNP_PIN_AIN_AMUX_ABUS4 7
/* Current Sink (MPP) */
#define QPNP_PIN_CS_OUT_5MA 0
#define QPNP_PIN_CS_OUT_10MA 1
#define QPNP_PIN_CS_OUT_15MA 2
#define QPNP_PIN_CS_OUT_20MA 3
#define QPNP_PIN_CS_OUT_25MA 4
#define QPNP_PIN_CS_OUT_30MA 5
#define QPNP_PIN_CS_OUT_35MA 6
#define QPNP_PIN_CS_OUT_40MA 7
/* ANALOG PASS SEL (GPIO LV/MV) */
#define QPNP_PIN_APASS_SEL_ATEST1 0
#define QPNP_PIN_APASS_SEL_ATEST2 1
#define QPNP_PIN_APASS_SEL_ATEST3 2
#define QPNP_PIN_APASS_SEL_ATEST4 3
/**
* struct qpnp_pin_cfg - structure to specify pin configurtion values
* @mode: indicates whether the pin should be input, output, or
* both for gpios. mpp pins also support bidirectional,
* analog in, analog out and current sink. This value
* should be of type QPNP_PIN_MODE_*.
* @output_type: indicates pin should be configured as CMOS or open
* drain. Should be of the type QPNP_PIN_OUT_BUF_*. This
* setting applies for gpios only.
* @invert: Invert the signal of the line -
* QPNP_PIN_INVERT_DISABLE or QPNP_PIN_INVERT_ENABLE.
* @pull: This parameter should be programmed to different values
* depending on whether it's GPIO or MPP.
* For GPIO, it indicates whether a pull up or pull down
* should be applied. If a pullup is required the
* current strength needs to be specified.
* Current values of 30uA, 1.5uA, 31.5uA, 1.5uA with 30uA
* boost are supported. This value should be one of
* the QPNP_PIN_GPIO_PULL_*. Note that the hardware ignores
* this configuration if the GPIO is not set to input or
* output open-drain mode.
* For MPP, it indicates whether a pullup should be
* applied for bidirectitional mode only. The hardware
* ignores the configuration when operating in other modes.
* This value should be one of the QPNP_PIN_MPP_PULL_*.
* @vin_sel: specifies the voltage level when the output is set to 1.
* For an input gpio specifies the voltage level at which
* the input is interpreted as a logical 1.
* @out_strength: the amount of current supplied for an output gpio,
* should be of the type QPNP_PIN_STRENGTH_*.
* @src_sel: select alternate function for the pin. Certain pins
* can be paired (shorted) with each other. Some pins
* can act as alternate functions. In the context of
* gpio, this acts as a source select. For mpps,
* this is an enable select.
* This parameter should be of type QPNP_PIN_SEL_*.
* @master_en: QPNP_PIN_MASTER_ENABLE = Enable features within the
* pin block based on configurations.
* QPNP_PIN_MASTER_DISABLE = Completely disable the pin
* block and let the pin float with high impedance
* regardless of other settings.
* @aout_ref: Set the analog output reference. This parameter should
* be of type QPNP_PIN_AOUT_*. This parameter only applies
* to mpp pins.
* @ain_route: Set the source for analog input. This parameter
* should be of type QPNP_PIN_AIN_*. This parameter only
* applies to mpp pins.
* @cs_out: Set the the amount of current to sync in mA. This
* parameter should be of type QPNP_PIN_CS_OUT_*. This
* parameter only applies to mpp pins.
* @apass_sel: Set the ATEST line to which the signal is to be
* routed to. The parameter should be of type
* QPNP_PIN_APASS_SEL_*. This
* parameter only applies to GPIO LV/MV pins.
* @dtest_sel: Select the DTEST line to which the signal needs
* is routed to. The parameter should be of type
* QPNP_PIN_DIG_IN_CTL_*. The parameter applies
* to both gpio and mpp pins.
*/
struct qpnp_pin_cfg {
int mode;
int output_type;
int invert;
int pull;
int vin_sel;
int out_strength;
int src_sel;
int master_en;
int aout_ref;
int ain_route;
int cs_out;
int apass_sel;
int dtest_sel;
};
/**
* qpnp_pin_config - Apply pin configuration for Linux gpio
* @gpio: Linux gpio number to configure.
* @param: parameters to configure.
*
* This routine takes a Linux gpio number that corresponds with a
* PMIC pin and applies the configuration specified in 'param'.
* This gpio number can be ascertained by of_get_gpio_flags() or
* the qpnp_pin_map_gpio() API.
*/
int qpnp_pin_config(int gpio, struct qpnp_pin_cfg *param);
/**
* qpnp_pin_map - Obtain Linux GPIO number from device spec
* @name: Name assigned by the 'label' binding for the primary node.
* @pmic_pin: PMIC pin number to lookup.
*
* This routine is used in legacy configurations that do not support
* Device Tree. If you are using Device Tree, you should not use this.
* For such cases, use of_get_gpio() or friends instead.
*/
int qpnp_pin_map(const char *name, uint32_t pmic_pin);