android_kernel_samsung_on5x.../include/linux/mfd/samsung/s2mpw01.h
2018-06-19 23:16:04 +02:00

142 lines
3.7 KiB
C

/*
* s2mpw01.h - Driver for the s2mpw01
*
* Copyright (C) 2015 Samsung Electrnoics
*
* 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.
*
* 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.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
*/
#ifndef __S2MPW01_MFD_H__
#define __S2MPW01_MFD_H__
#include <linux/platform_device.h>
#include <linux/regmap.h>
#include <linux/power/sec_charging_common.h>
#define MFD_DEV_NAME "s2mpw01"
#define M2SH(m) ((m) & 0x0F ? ((m) & 0x03 ? ((m) & 0x01 ? 0 : 1) : ((m) & 0x04 ? 2 : 3)) : \
((m) & 0x30 ? ((m) & 0x10 ? 4 : 5) : ((m) & 0x40 ? 6 : 7)))
#if defined(CONFIG_SEC_CHARGER_S2MPW01)
typedef struct s2mpw01_charger_platform_data {
sec_charging_current_t *charging_current_table;
int chg_float_voltage;
char *charger_name;
char *fuelgauge_name;
bool chg_eoc_dualpath;
uint32_t is_1MHz_switching:1;
/* 2nd full check */
sec_battery_full_charged_t full_check_type_2nd;
} s2mpw01_charger_platform_data_t;
#endif
/**
* sec_regulator_data - regulator data
* @id: regulator id
* @initdata: regulator init data (contraints, supplies, ...)
*/
struct s2mpw01_regulator_data {
int id;
struct regulator_init_data *initdata;
struct device_node *reg_node;
};
/*
* sec_opmode_data - regulator operation mode data
* @id: regulator id
* @mode: regulator operation mode
*/
struct sec_opmode_data {
int id;
unsigned int mode;
};
/*
* samsung regulator operation mode
* SEC_OPMODE_OFF Regulator always OFF
* SEC_OPMODE_ON Regulator always ON
* SEC_OPMODE_LOWPOWER Regulator is on in low-power mode
* SEC_OPMODE_SUSPEND Regulator is changed by PWREN pin
* If PWREN is high, regulator is on
* If PWREN is low, regulator is off
*/
enum sec_opmode {
SEC_OPMODE_OFF,
SEC_OPMODE_SUSPEND,
SEC_OPMODE_LOWPOWER,
SEC_OPMODE_ON,
};
/**
* struct sec_wtsr_smpl - settings for WTSR/SMPL
* @wtsr_en: WTSR Function Enable Control
* @smpl_en: SMPL Function Enable Control
* @wtsr_timer_val: Set the WTSR timer Threshold
* @smpl_timer_val: Set the SMPL timer Threshold
* @check_jigon: if this value is true, do not enable SMPL function when
* JIGONB is low(JIG cable is attached)
*/
struct sec_wtsr_smpl {
bool wtsr_en;
bool smpl_en;
int wtsr_timer_val;
int smpl_timer_val;
bool check_jigon;
};
struct s2mpw01_platform_data {
/* IRQ */
int irq_base;
int irq_gpio;
bool wakeup;
int num_regulators;
struct s2mpw01_regulator_data *regulators;
struct sec_opmode_data *opmode;
struct mfd_cell *sub_devices;
int num_subdevs;
int (*cfg_pmic_irq)(void);
int device_type;
int ono;
int buck_ramp_delay;
bool dvs_en;
/* ---- RTC ---- */
struct sec_wtsr_smpl *wtsr_smpl;
struct rtc_time *init_time;
bool use_i2c_speedy;
bool cache_data;
};
struct s2mpw01
{
struct regmap *regmap;
};
/* easier regulator block control : lock is aquired internally */
extern int swa_pmic_reg_read(u8 reg, void *dest);
extern int swa_pmic_reg_write(u8 reg, u8 value);
extern int swa_pmic_reg_update(u8 reg, u8 val, u8 mask);
/* easier rtc block control : lock is aquired internally */
extern int swa_pmic_rtc_read(u8 reg, void *dest);
extern int swa_pmic_rtc_write(u8 reg, u8 value);
extern int swa_pmic_rtc_update(u8 reg, u8 val, u8 mask);
#endif /* __S2MPW01_MFD_H__ */