6445b84abf
This patch support irq handling driver for s2mps11. As this patch use regmap_irq, s5m8767 and s5m8763 are modified with regmap_irq. Signed-off-by: Sangbeom Kim <sbkim73@samsung.com> Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
159 lines
3.9 KiB
C
159 lines
3.9 KiB
C
/*
|
|
* core.h
|
|
*
|
|
* copyright (c) 2011 Samsung Electronics Co., Ltd
|
|
* http://www.samsung.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 __LINUX_MFD_SEC_CORE_H
|
|
#define __LINUX_MFD_SEC_CORE_H
|
|
|
|
#define NUM_IRQ_REGS 4
|
|
|
|
enum sec_device_type {
|
|
S5M8751X,
|
|
S5M8763X,
|
|
S5M8767X,
|
|
S2MPS11X,
|
|
};
|
|
|
|
/**
|
|
* struct sec_pmic_dev - s5m87xx master device for sub-drivers
|
|
* @dev: master device of the chip (can be used to access platform data)
|
|
* @i2c: i2c client private data for regulator
|
|
* @rtc: i2c client private data for rtc
|
|
* @iolock: mutex for serializing io access
|
|
* @irqlock: mutex for buslock
|
|
* @irq_base: base IRQ number for sec-pmic, required for IRQs
|
|
* @irq: generic IRQ number for s5m87xx
|
|
* @ono: power onoff IRQ number for s5m87xx
|
|
* @irq_masks_cur: currently active value
|
|
* @irq_masks_cache: cached hardware value
|
|
* @type: indicate which s5m87xx "variant" is used
|
|
*/
|
|
struct sec_pmic_dev {
|
|
struct device *dev;
|
|
struct regmap *regmap;
|
|
struct i2c_client *i2c;
|
|
struct i2c_client *rtc;
|
|
struct mutex iolock;
|
|
struct mutex irqlock;
|
|
|
|
int device_type;
|
|
int irq_base;
|
|
int irq;
|
|
struct regmap_irq_chip_data *irq_data;
|
|
|
|
int ono;
|
|
u8 irq_masks_cur[NUM_IRQ_REGS];
|
|
u8 irq_masks_cache[NUM_IRQ_REGS];
|
|
int type;
|
|
bool wakeup;
|
|
};
|
|
|
|
int sec_irq_init(struct sec_pmic_dev *sec_pmic);
|
|
void sec_irq_exit(struct sec_pmic_dev *sec_pmic);
|
|
int sec_irq_resume(struct sec_pmic_dev *sec_pmic);
|
|
|
|
extern int sec_reg_read(struct sec_pmic_dev *sec_pmic, u8 reg, void *dest);
|
|
extern int sec_bulk_read(struct sec_pmic_dev *sec_pmic, u8 reg, int count, u8 *buf);
|
|
extern int sec_reg_write(struct sec_pmic_dev *sec_pmic, u8 reg, u8 value);
|
|
extern int sec_bulk_write(struct sec_pmic_dev *sec_pmic, u8 reg, int count, u8 *buf);
|
|
extern int sec_reg_update(struct sec_pmic_dev *sec_pmic, u8 reg, u8 val, u8 mask);
|
|
|
|
struct sec_platform_data {
|
|
struct sec_regulator_data *regulators;
|
|
struct sec_opmode_data *opmode;
|
|
int device_type;
|
|
int num_regulators;
|
|
|
|
int irq_base;
|
|
int (*cfg_pmic_irq)(void);
|
|
|
|
int ono;
|
|
bool wakeup;
|
|
bool buck_voltage_lock;
|
|
|
|
int buck_gpios[3];
|
|
int buck_ds[3];
|
|
int buck2_voltage[8];
|
|
bool buck2_gpiodvs;
|
|
int buck3_voltage[8];
|
|
bool buck3_gpiodvs;
|
|
int buck4_voltage[8];
|
|
bool buck4_gpiodvs;
|
|
|
|
int buck_set1;
|
|
int buck_set2;
|
|
int buck_set3;
|
|
int buck2_enable;
|
|
int buck3_enable;
|
|
int buck4_enable;
|
|
int buck_default_idx;
|
|
int buck2_default_idx;
|
|
int buck3_default_idx;
|
|
int buck4_default_idx;
|
|
|
|
int buck_ramp_delay;
|
|
|
|
int buck2_ramp_delay;
|
|
int buck34_ramp_delay;
|
|
int buck5_ramp_delay;
|
|
int buck16_ramp_delay;
|
|
int buck7810_ramp_delay;
|
|
int buck9_ramp_delay;
|
|
|
|
bool buck2_ramp_enable;
|
|
bool buck3_ramp_enable;
|
|
bool buck4_ramp_enable;
|
|
bool buck6_ramp_enable;
|
|
|
|
int buck2_init;
|
|
int buck3_init;
|
|
int buck4_init;
|
|
};
|
|
|
|
/**
|
|
* sec_regulator_data - regulator data
|
|
* @id: regulator id
|
|
* @initdata: regulator init data (contraints, supplies, ...)
|
|
*/
|
|
struct sec_regulator_data {
|
|
int id;
|
|
struct regulator_init_data *initdata;
|
|
};
|
|
|
|
/*
|
|
* sec_opmode_data - regulator operation mode data
|
|
* @id: regulator id
|
|
* @mode: regulator operation mode
|
|
*/
|
|
struct sec_opmode_data {
|
|
int id;
|
|
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_ON,
|
|
SEC_OPMODE_LOWPOWER,
|
|
SEC_OPMODE_SUSPEND,
|
|
};
|
|
|
|
#endif /* __LINUX_MFD_SEC_CORE_H */
|