Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
507792c9
Commit
507792c9
authored
Mar 19, 2014
by
Lee Jones
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'ib-mfd-regulator-3.15' into HEAD
parents
df8eddb3
ba3e31f8
Changes
11
Show whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
1260 additions
and
29 deletions
+1260
-29
Documentation/devicetree/bindings/mfd/s2mpa01.txt
Documentation/devicetree/bindings/mfd/s2mpa01.txt
+90
-0
drivers/mfd/sec-core.c
drivers/mfd/sec-core.c
+102
-10
drivers/mfd/sec-irq.c
drivers/mfd/sec-irq.c
+92
-5
drivers/regulator/Kconfig
drivers/regulator/Kconfig
+7
-0
drivers/regulator/Makefile
drivers/regulator/Makefile
+1
-0
drivers/regulator/s2mpa01.c
drivers/regulator/s2mpa01.c
+481
-0
include/linux/mfd/samsung/core.h
include/linux/mfd/samsung/core.h
+13
-6
include/linux/mfd/samsung/irq.h
include/linux/mfd/samsung/irq.h
+79
-2
include/linux/mfd/samsung/rtc.h
include/linux/mfd/samsung/rtc.h
+51
-6
include/linux/mfd/samsung/s2mpa01.h
include/linux/mfd/samsung/s2mpa01.h
+192
-0
include/linux/mfd/samsung/s2mps14.h
include/linux/mfd/samsung/s2mps14.h
+152
-0
No files found.
Documentation/devicetree/bindings/mfd/s2mpa01.txt
0 → 100644
View file @
507792c9
* Samsung S2MPA01 Voltage and Current Regulator
The Samsung S2MPA01 is a multi-function device which includes high
efficiency buck converters including Dual-Phase buck converter, various LDOs,
and an RTC. It is interfaced to the host controller using an I2C interface.
Each sub-block is addressed by the host system using different I2C slave
addresses.
Required properties:
- compatible: Should be "samsung,s2mpa01-pmic".
- reg: Specifies the I2C slave address of the PMIC block. It should be 0x66.
Optional properties:
- interrupt-parent: Specifies the phandle of the interrupt controller to which
the interrupts from s2mpa01 are delivered to.
- interrupts: An interrupt specifier for the sole interrupt generated by the
device.
Optional nodes:
- regulators: The regulators of s2mpa01 that have to be instantiated should be
included in a sub-node named 'regulators'. Regulator nodes and constraints
included in this sub-node use the standard regulator bindings which are
documented elsewhere.
Properties for BUCK regulator nodes:
- regulator-ramp-delay: ramp delay in uV/us. May be 6250, 12500
(default), 25000, or 50000. May be 0 for disabling the ramp delay on
BUCK{1,2,3,4}.
In the absence of the regulator-ramp-delay property, the default ramp
delay will be used.
NOTE: Some BUCKs share the ramp rate setting i.e. same ramp value will be set
for a particular group of BUCKs. So provide same regulator-ramp-delay=<value>.
The following BUCKs share ramp settings:
* 1 and 6
* 2 and 4
* 8, 9, and 10
The following are the names of the regulators that the s2mpa01 PMIC block
supports. Note: The 'n' in LDOn and BUCKn represents the LDO or BUCK number
as per the datasheet of s2mpa01.
- LDOn
- valid values for n are 1 to 26
- Example: LDO1, LD02, LDO26
- BUCKn
- valid values for n are 1 to 10.
- Example: BUCK1, BUCK2, BUCK9
Example:
s2mpa01_pmic@66 {
compatible = "samsung,s2mpa01-pmic";
reg = <0x66>;
regulators {
ldo1_reg: LDO1 {
regulator-name = "VDD_ALIVE";
regulator-min-microvolt = <1000000>;
regulator-max-microvolt = <1000000>;
};
ldo2_reg: LDO2 {
regulator-name = "VDDQ_MMC2";
regulator-min-microvolt = <2800000>;
regulator-max-microvolt = <2800000>;
regulator-always-on;
};
buck1_reg: BUCK1 {
regulator-name = "vdd_mif";
regulator-min-microvolt = <950000>;
regulator-max-microvolt = <1350000>;
regulator-always-on;
regulator-boot-on;
};
buck2_reg: BUCK2 {
regulator-name = "vdd_arm";
regulator-min-microvolt = <950000>;
regulator-max-microvolt = <1350000>;
regulator-always-on;
regulator-boot-on;
regulator-ramp-delay = <50000>;
};
};
};
drivers/mfd/sec-core.c
View file @
507792c9
...
...
@@ -26,7 +26,9 @@
#include <linux/mfd/samsung/core.h>
#include <linux/mfd/samsung/irq.h>
#include <linux/mfd/samsung/rtc.h>
#include <linux/mfd/samsung/s2mpa01.h>
#include <linux/mfd/samsung/s2mps11.h>
#include <linux/mfd/samsung/s2mps14.h>
#include <linux/mfd/samsung/s5m8763.h>
#include <linux/mfd/samsung/s5m8767.h>
#include <linux/regmap.h>
...
...
@@ -69,18 +71,53 @@ static const struct mfd_cell s2mps11_devs[] = {
}
};
static
const
struct
mfd_cell
s2mps14_devs
[]
=
{
{
.
name
=
"s2mps14-pmic"
,
},
{
.
name
=
"s2mps14-rtc"
,
},
{
.
name
=
"s2mps14-clk"
,
}
};
static
const
struct
mfd_cell
s2mpa01_devs
[]
=
{
{
.
name
=
"s2mpa01-pmic"
,
},
};
#ifdef CONFIG_OF
static
struct
of_device_id
sec_dt_match
[]
=
{
{
.
compatible
=
"samsung,s5m8767-pmic"
,
.
data
=
(
void
*
)
S5M8767X
,
},
{
.
compatible
=
"samsung,s2mps11-pmic"
,
},
{
.
compatible
=
"samsung,s2mps11-pmic"
,
.
data
=
(
void
*
)
S2MPS11X
,
},
{
.
compatible
=
"samsung,s2mps14-pmic"
,
.
data
=
(
void
*
)
S2MPS14X
,
},
{
.
compatible
=
"samsung,s2mpa01-pmic"
,
.
data
=
(
void
*
)
S2MPA01
,
},
{
/* Sentinel */
},
{},
};
#endif
static
bool
s2mpa01_volatile
(
struct
device
*
dev
,
unsigned
int
reg
)
{
switch
(
reg
)
{
case
S2MPA01_REG_INT1M
:
case
S2MPA01_REG_INT2M
:
case
S2MPA01_REG_INT3M
:
return
false
;
default:
return
true
;
}
}
static
bool
s2mps11_volatile
(
struct
device
*
dev
,
unsigned
int
reg
)
{
switch
(
reg
)
{
...
...
@@ -111,6 +148,15 @@ static const struct regmap_config sec_regmap_config = {
.
val_bits
=
8
,
};
static
const
struct
regmap_config
s2mpa01_regmap_config
=
{
.
reg_bits
=
8
,
.
val_bits
=
8
,
.
max_register
=
S2MPA01_REG_LDO_OVCB4
,
.
volatile_reg
=
s2mpa01_volatile
,
.
cache_type
=
REGCACHE_FLAT
,
};
static
const
struct
regmap_config
s2mps11_regmap_config
=
{
.
reg_bits
=
8
,
.
val_bits
=
8
,
...
...
@@ -120,6 +166,15 @@ static const struct regmap_config s2mps11_regmap_config = {
.
cache_type
=
REGCACHE_FLAT
,
};
static
const
struct
regmap_config
s2mps14_regmap_config
=
{
.
reg_bits
=
8
,
.
val_bits
=
8
,
.
max_register
=
S2MPS14_REG_LDODSCH3
,
.
volatile_reg
=
s2mps11_volatile
,
.
cache_type
=
REGCACHE_FLAT
,
};
static
const
struct
regmap_config
s5m8763_regmap_config
=
{
.
reg_bits
=
8
,
.
val_bits
=
8
,
...
...
@@ -138,9 +193,18 @@ static const struct regmap_config s5m8767_regmap_config = {
.
cache_type
=
REGCACHE_FLAT
,
};
static
const
struct
regmap_config
sec_rtc_regmap_config
=
{
static
const
struct
regmap_config
s5m_rtc_regmap_config
=
{
.
reg_bits
=
8
,
.
val_bits
=
8
,
.
max_register
=
SEC_RTC_REG_MAX
,
};
static
const
struct
regmap_config
s2mps14_rtc_regmap_config
=
{
.
reg_bits
=
8
,
.
val_bits
=
8
,
.
max_register
=
S2MPS_RTC_REG_MAX
,
};
#ifdef CONFIG_OF
...
...
@@ -180,24 +244,24 @@ static struct sec_platform_data *sec_pmic_i2c_parse_dt_pdata(
}
#endif
static
inline
int
sec_i2c_get_driver_data
(
struct
i2c_client
*
i2c
,
static
inline
unsigned
long
sec_i2c_get_driver_data
(
struct
i2c_client
*
i2c
,
const
struct
i2c_device_id
*
id
)
{
#ifdef CONFIG_OF
if
(
i2c
->
dev
.
of_node
)
{
const
struct
of_device_id
*
match
;
match
=
of_match_node
(
sec_dt_match
,
i2c
->
dev
.
of_node
);
return
(
int
)
match
->
data
;
return
(
unsigned
long
)
match
->
data
;
}
#endif
return
(
int
)
id
->
driver_data
;
return
id
->
driver_data
;
}
static
int
sec_pmic_probe
(
struct
i2c_client
*
i2c
,
const
struct
i2c_device_id
*
id
)
{
struct
sec_platform_data
*
pdata
=
dev_get_platdata
(
&
i2c
->
dev
);
const
struct
regmap_config
*
regmap
;
const
struct
regmap_config
*
regmap
,
*
regmap_rtc
;
struct
sec_pmic_dev
*
sec_pmic
;
int
ret
;
...
...
@@ -229,17 +293,34 @@ static int sec_pmic_probe(struct i2c_client *i2c,
}
switch
(
sec_pmic
->
device_type
)
{
case
S2MPA01
:
regmap
=
&
s2mpa01_regmap_config
;
break
;
case
S2MPS11X
:
regmap
=
&
s2mps11_regmap_config
;
/*
* The rtc-s5m driver does not support S2MPS11 and there
* is no mfd_cell for S2MPS11 RTC device.
* However we must pass something to devm_regmap_init_i2c()
* so use S5M-like regmap config even though it wouldn't work.
*/
regmap_rtc
=
&
s5m_rtc_regmap_config
;
break
;
case
S2MPS14X
:
regmap
=
&
s2mps14_regmap_config
;
regmap_rtc
=
&
s2mps14_rtc_regmap_config
;
break
;
case
S5M8763X
:
regmap
=
&
s5m8763_regmap_config
;
regmap_rtc
=
&
s5m_rtc_regmap_config
;
break
;
case
S5M8767X
:
regmap
=
&
s5m8767_regmap_config
;
regmap_rtc
=
&
s5m_rtc_regmap_config
;
break
;
default:
regmap
=
&
sec_regmap_config
;
regmap_rtc
=
&
s5m_rtc_regmap_config
;
break
;
}
...
...
@@ -252,10 +333,13 @@ static int sec_pmic_probe(struct i2c_client *i2c,
}
sec_pmic
->
rtc
=
i2c_new_dummy
(
i2c
->
adapter
,
RTC_I2C_ADDR
);
if
(
!
sec_pmic
->
rtc
)
{
dev_err
(
&
i2c
->
dev
,
"Failed to allocate I2C for RTC
\n
"
);
return
-
ENODEV
;
}
i2c_set_clientdata
(
sec_pmic
->
rtc
,
sec_pmic
);
sec_pmic
->
regmap_rtc
=
devm_regmap_init_i2c
(
sec_pmic
->
rtc
,
&
sec_rtc_regmap_config
);
sec_pmic
->
regmap_rtc
=
devm_regmap_init_i2c
(
sec_pmic
->
rtc
,
regmap_rtc
);
if
(
IS_ERR
(
sec_pmic
->
regmap_rtc
))
{
ret
=
PTR_ERR
(
sec_pmic
->
regmap_rtc
);
dev_err
(
&
i2c
->
dev
,
"Failed to allocate RTC register map: %d
\n
"
,
...
...
@@ -283,10 +367,18 @@ static int sec_pmic_probe(struct i2c_client *i2c,
ret
=
mfd_add_devices
(
sec_pmic
->
dev
,
-
1
,
s5m8767_devs
,
ARRAY_SIZE
(
s5m8767_devs
),
NULL
,
0
,
NULL
);
break
;
case
S2MPA01
:
ret
=
mfd_add_devices
(
sec_pmic
->
dev
,
-
1
,
s2mpa01_devs
,
ARRAY_SIZE
(
s2mpa01_devs
),
NULL
,
0
,
NULL
);
break
;
case
S2MPS11X
:
ret
=
mfd_add_devices
(
sec_pmic
->
dev
,
-
1
,
s2mps11_devs
,
ARRAY_SIZE
(
s2mps11_devs
),
NULL
,
0
,
NULL
);
break
;
case
S2MPS14X
:
ret
=
mfd_add_devices
(
sec_pmic
->
dev
,
-
1
,
s2mps14_devs
,
ARRAY_SIZE
(
s2mps14_devs
),
NULL
,
0
,
NULL
);
break
;
default:
/* If this happens the probe function is problem */
BUG
();
...
...
drivers/mfd/sec-irq.c
View file @
507792c9
/*
* sec-irq.c
*
* Copyright (c) 2011 Samsung Electronics Co., Ltd
* Copyright (c) 2011
-2014
Samsung Electronics Co., Ltd
* http://www.samsung.com
*
* This program is free software; you can redistribute it and/or modify it
...
...
@@ -19,6 +19,7 @@
#include <linux/mfd/samsung/core.h>
#include <linux/mfd/samsung/irq.h>
#include <linux/mfd/samsung/s2mps11.h>
#include <linux/mfd/samsung/s2mps14.h>
#include <linux/mfd/samsung/s5m8763.h>
#include <linux/mfd/samsung/s5m8767.h>
...
...
@@ -59,13 +60,13 @@ static const struct regmap_irq s2mps11_irqs[] = {
.
reg_offset
=
1
,
.
mask
=
S2MPS11_IRQ_RTC60S_MASK
,
},
[
S2MPS11_IRQ_RTCA
1
]
=
{
[
S2MPS11_IRQ_RTCA
0
]
=
{
.
reg_offset
=
1
,
.
mask
=
S2MPS11_IRQ_RTCA
1
_MASK
,
.
mask
=
S2MPS11_IRQ_RTCA
0
_MASK
,
},
[
S2MPS11_IRQ_RTCA
2
]
=
{
[
S2MPS11_IRQ_RTCA
1
]
=
{
.
reg_offset
=
1
,
.
mask
=
S2MPS11_IRQ_RTCA
2
_MASK
,
.
mask
=
S2MPS11_IRQ_RTCA
1
_MASK
,
},
[
S2MPS11_IRQ_SMPL
]
=
{
.
reg_offset
=
1
,
...
...
@@ -89,6 +90,76 @@ static const struct regmap_irq s2mps11_irqs[] = {
},
};
static
const
struct
regmap_irq
s2mps14_irqs
[]
=
{
[
S2MPS14_IRQ_PWRONF
]
=
{
.
reg_offset
=
0
,
.
mask
=
S2MPS11_IRQ_PWRONF_MASK
,
},
[
S2MPS14_IRQ_PWRONR
]
=
{
.
reg_offset
=
0
,
.
mask
=
S2MPS11_IRQ_PWRONR_MASK
,
},
[
S2MPS14_IRQ_JIGONBF
]
=
{
.
reg_offset
=
0
,
.
mask
=
S2MPS11_IRQ_JIGONBF_MASK
,
},
[
S2MPS14_IRQ_JIGONBR
]
=
{
.
reg_offset
=
0
,
.
mask
=
S2MPS11_IRQ_JIGONBR_MASK
,
},
[
S2MPS14_IRQ_ACOKBF
]
=
{
.
reg_offset
=
0
,
.
mask
=
S2MPS11_IRQ_ACOKBF_MASK
,
},
[
S2MPS14_IRQ_ACOKBR
]
=
{
.
reg_offset
=
0
,
.
mask
=
S2MPS11_IRQ_ACOKBR_MASK
,
},
[
S2MPS14_IRQ_PWRON1S
]
=
{
.
reg_offset
=
0
,
.
mask
=
S2MPS11_IRQ_PWRON1S_MASK
,
},
[
S2MPS14_IRQ_MRB
]
=
{
.
reg_offset
=
0
,
.
mask
=
S2MPS11_IRQ_MRB_MASK
,
},
[
S2MPS14_IRQ_RTC60S
]
=
{
.
reg_offset
=
1
,
.
mask
=
S2MPS11_IRQ_RTC60S_MASK
,
},
[
S2MPS14_IRQ_RTCA1
]
=
{
.
reg_offset
=
1
,
.
mask
=
S2MPS11_IRQ_RTCA1_MASK
,
},
[
S2MPS14_IRQ_RTCA0
]
=
{
.
reg_offset
=
1
,
.
mask
=
S2MPS11_IRQ_RTCA0_MASK
,
},
[
S2MPS14_IRQ_SMPL
]
=
{
.
reg_offset
=
1
,
.
mask
=
S2MPS11_IRQ_SMPL_MASK
,
},
[
S2MPS14_IRQ_RTC1S
]
=
{
.
reg_offset
=
1
,
.
mask
=
S2MPS11_IRQ_RTC1S_MASK
,
},
[
S2MPS14_IRQ_WTSR
]
=
{
.
reg_offset
=
1
,
.
mask
=
S2MPS11_IRQ_WTSR_MASK
,
},
[
S2MPS14_IRQ_INT120C
]
=
{
.
reg_offset
=
2
,
.
mask
=
S2MPS11_IRQ_INT120C_MASK
,
},
[
S2MPS14_IRQ_INT140C
]
=
{
.
reg_offset
=
2
,
.
mask
=
S2MPS11_IRQ_INT140C_MASK
,
},
[
S2MPS14_IRQ_TSD
]
=
{
.
reg_offset
=
2
,
.
mask
=
S2MPS14_IRQ_TSD_MASK
,
},
};
static
const
struct
regmap_irq
s5m8767_irqs
[]
=
{
[
S5M8767_IRQ_PWRR
]
=
{
...
...
@@ -246,6 +317,16 @@ static const struct regmap_irq_chip s2mps11_irq_chip = {
.
ack_base
=
S2MPS11_REG_INT1
,
};
static
const
struct
regmap_irq_chip
s2mps14_irq_chip
=
{
.
name
=
"s2mps14"
,
.
irqs
=
s2mps14_irqs
,
.
num_irqs
=
ARRAY_SIZE
(
s2mps14_irqs
),
.
num_regs
=
3
,
.
status_base
=
S2MPS14_REG_INT1
,
.
mask_base
=
S2MPS14_REG_INT1M
,
.
ack_base
=
S2MPS14_REG_INT1
,
};
static
const
struct
regmap_irq_chip
s5m8767_irq_chip
=
{
.
name
=
"s5m8767"
,
.
irqs
=
s5m8767_irqs
,
...
...
@@ -297,6 +378,12 @@ int sec_irq_init(struct sec_pmic_dev *sec_pmic)
sec_pmic
->
irq_base
,
&
s2mps11_irq_chip
,
&
sec_pmic
->
irq_data
);
break
;
case
S2MPS14X
:
ret
=
regmap_add_irq_chip
(
sec_pmic
->
regmap_pmic
,
sec_pmic
->
irq
,
IRQF_TRIGGER_FALLING
|
IRQF_ONESHOT
,
sec_pmic
->
irq_base
,
&
s2mps14_irq_chip
,
&
sec_pmic
->
irq_data
);
break
;
default:
dev_err
(
sec_pmic
->
dev
,
"Unknown device type %d
\n
"
,
sec_pmic
->
device_type
);
...
...
drivers/regulator/Kconfig
View file @
507792c9
...
...
@@ -416,6 +416,13 @@ config REGULATOR_RC5T583
through regulator interface. The device supports multiple DCDC/LDO
outputs which can be controlled by i2c communication.
config REGULATOR_S2MPA01
tristate "Samsung S2MPA01 voltage regulator"
depends on MFD_SEC_CORE
help
This driver controls Samsung S2MPA01 voltage output regulator
via I2C bus. S2MPA01 has 10 Bucks and 26 LDO outputs.
config REGULATOR_S2MPS11
tristate "Samsung S2MPS11 voltage regulator"
depends on MFD_SEC_CORE
...
...
drivers/regulator/Makefile
View file @
507792c9
...
...
@@ -57,6 +57,7 @@ obj-$(CONFIG_REGULATOR_TPS51632) += tps51632-regulator.o
obj-$(CONFIG_REGULATOR_PCAP)
+=
pcap-regulator.o
obj-$(CONFIG_REGULATOR_PCF50633)
+=
pcf50633-regulator.o
obj-$(CONFIG_REGULATOR_RC5T583)
+=
rc5t583-regulator.o
obj-$(CONFIG_REGULATOR_S2MPA01)
+=
s2mpa01.o
obj-$(CONFIG_REGULATOR_S2MPS11)
+=
s2mps11.o
obj-$(CONFIG_REGULATOR_S5M8767)
+=
s5m8767.o
obj-$(CONFIG_REGULATOR_STW481X_VMMC)
+=
stw481x-vmmc.o
...
...
drivers/regulator/s2mpa01.c
0 → 100644
View file @
507792c9
/*
* Copyright (c) 2013 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.
*
*/
#include <linux/bug.h>
#include <linux/err.h>
#include <linux/gpio.h>
#include <linux/slab.h>
#include <linux/module.h>
#include <linux/of.h>
#include <linux/regmap.h>
#include <linux/platform_device.h>
#include <linux/regulator/driver.h>
#include <linux/regulator/machine.h>
#include <linux/regulator/of_regulator.h>
#include <linux/mfd/samsung/core.h>
#include <linux/mfd/samsung/s2mpa01.h>
#define S2MPA01_REGULATOR_CNT ARRAY_SIZE(regulators)
struct
s2mpa01_info
{
int
ramp_delay24
;
int
ramp_delay3
;
int
ramp_delay5
;
int
ramp_delay16
;
int
ramp_delay7
;
int
ramp_delay8910
;
};
static
int
get_ramp_delay
(
int
ramp_delay
)
{
unsigned
char
cnt
=
0
;
ramp_delay
/=
6250
;
while
(
true
)
{
ramp_delay
=
ramp_delay
>>
1
;
if
(
ramp_delay
==
0
)
break
;
cnt
++
;
}
if
(
cnt
>
3
)
cnt
=
3
;
return
cnt
;
}
static
int
s2mpa01_regulator_set_voltage_time_sel
(
struct
regulator_dev
*
rdev
,
unsigned
int
old_selector
,
unsigned
int
new_selector
)
{
struct
s2mpa01_info
*
s2mpa01
=
rdev_get_drvdata
(
rdev
);
unsigned
int
ramp_delay
=
0
;
int
old_volt
,
new_volt
;
switch
(
rdev
->
desc
->
id
)
{
case
S2MPA01_BUCK2
:
case
S2MPA01_BUCK4
:
ramp_delay
=
s2mpa01
->
ramp_delay24
;
break
;
case
S2MPA01_BUCK3
:
ramp_delay
=
s2mpa01
->
ramp_delay3
;
break
;
case
S2MPA01_BUCK5
:
ramp_delay
=
s2mpa01
->
ramp_delay5
;
break
;
case
S2MPA01_BUCK1
:
case
S2MPA01_BUCK6
:
ramp_delay
=
s2mpa01
->
ramp_delay16
;
break
;
case
S2MPA01_BUCK7
:
ramp_delay
=
s2mpa01
->
ramp_delay7
;
break
;
case
S2MPA01_BUCK8
:
case
S2MPA01_BUCK9
:
case
S2MPA01_BUCK10
:
ramp_delay
=
s2mpa01
->
ramp_delay8910
;
break
;
}
if
(
ramp_delay
==
0
)
ramp_delay
=
rdev
->
desc
->
ramp_delay
;
old_volt
=
rdev
->
desc
->
min_uV
+
(
rdev
->
desc
->
uV_step
*
old_selector
);
new_volt
=
rdev
->
desc
->
min_uV
+
(
rdev
->
desc
->
uV_step
*
new_selector
);
return
DIV_ROUND_UP
(
abs
(
new_volt
-
old_volt
),
ramp_delay
);
}
static
int
s2mpa01_set_ramp_delay
(
struct
regulator_dev
*
rdev
,
int
ramp_delay
)
{
struct
s2mpa01_info
*
s2mpa01
=
rdev_get_drvdata
(
rdev
);
unsigned
int
ramp_val
,
ramp_shift
,
ramp_reg
=
S2MPA01_REG_RAMP2
;
unsigned
int
ramp_enable
=
1
,
enable_shift
=
0
;
int
ret
;
switch
(
rdev
->
desc
->
id
)
{
case
S2MPA01_BUCK1
:
enable_shift
=
S2MPA01_BUCK1_RAMP_EN_SHIFT
;
if
(
!
ramp_delay
)
{
ramp_enable
=
0
;
break
;
}
if
(
ramp_delay
>
s2mpa01
->
ramp_delay16
)
s2mpa01
->
ramp_delay16
=
ramp_delay
;
else
ramp_delay
=
s2mpa01
->
ramp_delay16
;
ramp_shift
=
S2MPA01_BUCK16_RAMP_SHIFT
;
ramp_reg
=
S2MPA01_REG_RAMP1
;
break
;
case
S2MPA01_BUCK2
:
enable_shift
=
S2MPA01_BUCK2_RAMP_EN_SHIFT
;
if
(
!
ramp_delay
)
{
ramp_enable
=
0
;
break
;
}
if
(
ramp_delay
>
s2mpa01
->
ramp_delay24
)
s2mpa01
->
ramp_delay24
=
ramp_delay
;
else
ramp_delay
=
s2mpa01
->
ramp_delay24
;
ramp_shift
=
S2MPA01_BUCK24_RAMP_SHIFT
;
ramp_reg
=
S2MPA01_REG_RAMP1
;
break
;
case
S2MPA01_BUCK3
:
enable_shift
=
S2MPA01_BUCK3_RAMP_EN_SHIFT
;
if
(
!
ramp_delay
)
{
ramp_enable
=
0
;
break
;
}
s2mpa01
->
ramp_delay3
=
ramp_delay
;
ramp_shift
=
S2MPA01_BUCK3_RAMP_SHIFT
;
ramp_reg
=
S2MPA01_REG_RAMP1
;
break
;
case
S2MPA01_BUCK4
:
enable_shift
=
S2MPA01_BUCK4_RAMP_EN_SHIFT
;
if
(
!
ramp_delay
)
{
ramp_enable
=
0
;
break
;
}
if
(
ramp_delay
>
s2mpa01
->
ramp_delay24
)
s2mpa01
->
ramp_delay24
=
ramp_delay
;
else
ramp_delay
=
s2mpa01
->
ramp_delay24
;
ramp_shift
=
S2MPA01_BUCK24_RAMP_SHIFT
;
ramp_reg
=
S2MPA01_REG_RAMP1
;
break
;
case
S2MPA01_BUCK5
:
s2mpa01
->
ramp_delay5
=
ramp_delay
;
ramp_shift
=
S2MPA01_BUCK5_RAMP_SHIFT
;
break
;
case
S2MPA01_BUCK6
:
if
(
ramp_delay
>
s2mpa01
->
ramp_delay16
)
s2mpa01
->
ramp_delay16
=
ramp_delay
;
else
ramp_delay
=
s2mpa01
->
ramp_delay16
;
ramp_shift
=
S2MPA01_BUCK16_RAMP_SHIFT
;
break
;
case
S2MPA01_BUCK7
:
s2mpa01
->
ramp_delay7
=
ramp_delay
;
ramp_shift
=
S2MPA01_BUCK7_RAMP_SHIFT
;
break
;
case
S2MPA01_BUCK8
:
case
S2MPA01_BUCK9
:
case
S2MPA01_BUCK10
:
if
(
ramp_delay
>
s2mpa01
->
ramp_delay8910
)
s2mpa01
->
ramp_delay8910
=
ramp_delay
;
else
ramp_delay
=
s2mpa01
->
ramp_delay8910
;
ramp_shift
=
S2MPA01_BUCK8910_RAMP_SHIFT
;
break
;
default:
return
0
;
}
if
(
!
ramp_enable
)
goto
ramp_disable
;
if
(
enable_shift
)
{
ret
=
regmap_update_bits
(
rdev
->
regmap
,
S2MPA01_REG_RAMP1
,
1
<<
enable_shift
,
1
<<
enable_shift
);
if
(
ret
)
{
dev_err
(
&
rdev
->
dev
,
"failed to enable ramp rate
\n
"
);
return
ret
;
}
}
ramp_val
=
get_ramp_delay
(
ramp_delay
);
return
regmap_update_bits
(
rdev
->
regmap
,
ramp_reg
,
0x3
<<
ramp_shift
,
ramp_val
<<
ramp_shift
);
ramp_disable:
return
regmap_update_bits
(
rdev
->
regmap
,
S2MPA01_REG_RAMP1
,
1
<<
enable_shift
,
0
);
}
static
struct
regulator_ops
s2mpa01_ldo_ops
=
{
.
list_voltage
=
regulator_list_voltage_linear
,
.
map_voltage
=
regulator_map_voltage_linear
,
.
is_enabled
=
regulator_is_enabled_regmap
,
.
enable
=
regulator_enable_regmap
,
.
disable
=
regulator_disable_regmap
,
.
get_voltage_sel
=
regulator_get_voltage_sel_regmap
,
.
set_voltage_sel
=
regulator_set_voltage_sel_regmap
,
.
set_voltage_time_sel
=
regulator_set_voltage_time_sel
,
};
static
struct
regulator_ops
s2mpa01_buck_ops
=
{
.
list_voltage
=
regulator_list_voltage_linear
,
.
map_voltage
=
regulator_map_voltage_linear
,
.
is_enabled
=
regulator_is_enabled_regmap
,
.
enable
=
regulator_enable_regmap
,
.
disable
=
regulator_disable_regmap
,
.
get_voltage_sel
=
regulator_get_voltage_sel_regmap
,
.
set_voltage_sel
=
regulator_set_voltage_sel_regmap
,
.
set_voltage_time_sel
=
s2mpa01_regulator_set_voltage_time_sel
,
.
set_ramp_delay
=
s2mpa01_set_ramp_delay
,
};
#define regulator_desc_ldo1(num) { \
.name = "LDO"#num, \
.id = S2MPA01_LDO##num, \
.ops = &s2mpa01_ldo_ops, \
.type = REGULATOR_VOLTAGE, \
.owner = THIS_MODULE, \
.min_uV = S2MPA01_LDO_MIN, \
.uV_step = S2MPA01_LDO_STEP1, \
.n_voltages = S2MPA01_LDO_N_VOLTAGES, \
.vsel_reg = S2MPA01_REG_L1CTRL + num - 1, \
.vsel_mask = S2MPA01_LDO_VSEL_MASK, \
.enable_reg = S2MPA01_REG_L1CTRL + num - 1, \
.enable_mask = S2MPA01_ENABLE_MASK \
}
#define regulator_desc_ldo2(num) { \
.name = "LDO"#num, \
.id = S2MPA01_LDO##num, \
.ops = &s2mpa01_ldo_ops, \
.type = REGULATOR_VOLTAGE, \
.owner = THIS_MODULE, \
.min_uV = S2MPA01_LDO_MIN, \
.uV_step = S2MPA01_LDO_STEP2, \
.n_voltages = S2MPA01_LDO_N_VOLTAGES, \
.vsel_reg = S2MPA01_REG_L1CTRL + num - 1, \
.vsel_mask = S2MPA01_LDO_VSEL_MASK, \
.enable_reg = S2MPA01_REG_L1CTRL + num - 1, \
.enable_mask = S2MPA01_ENABLE_MASK \
}
#define regulator_desc_buck1_4(num) { \
.name = "BUCK"#num, \
.id = S2MPA01_BUCK##num, \
.ops = &s2mpa01_buck_ops, \
.type = REGULATOR_VOLTAGE, \
.owner = THIS_MODULE, \
.min_uV = S2MPA01_BUCK_MIN1, \
.uV_step = S2MPA01_BUCK_STEP1, \
.n_voltages = S2MPA01_BUCK_N_VOLTAGES, \
.ramp_delay = S2MPA01_RAMP_DELAY, \
.vsel_reg = S2MPA01_REG_B1CTRL2 + (num - 1) * 2, \
.vsel_mask = S2MPA01_BUCK_VSEL_MASK, \
.enable_reg = S2MPA01_REG_B1CTRL1 + (num - 1) * 2, \
.enable_mask = S2MPA01_ENABLE_MASK \
}
#define regulator_desc_buck5 { \
.name = "BUCK5", \
.id = S2MPA01_BUCK5, \
.ops = &s2mpa01_buck_ops, \
.type = REGULATOR_VOLTAGE, \
.owner = THIS_MODULE, \
.min_uV = S2MPA01_BUCK_MIN2, \
.uV_step = S2MPA01_BUCK_STEP1, \
.n_voltages = S2MPA01_BUCK_N_VOLTAGES, \
.ramp_delay = S2MPA01_RAMP_DELAY, \
.vsel_reg = S2MPA01_REG_B5CTRL2, \
.vsel_mask = S2MPA01_BUCK_VSEL_MASK, \
.enable_reg = S2MPA01_REG_B5CTRL1, \
.enable_mask = S2MPA01_ENABLE_MASK \
}
#define regulator_desc_buck6_7(num) { \
.name = "BUCK"#num, \
.id = S2MPA01_BUCK##num, \
.ops = &s2mpa01_buck_ops, \
.type = REGULATOR_VOLTAGE, \
.owner = THIS_MODULE, \
.min_uV = S2MPA01_BUCK_MIN1, \
.uV_step = S2MPA01_BUCK_STEP1, \
.n_voltages = S2MPA01_BUCK_N_VOLTAGES, \
.ramp_delay = S2MPA01_RAMP_DELAY, \
.vsel_reg = S2MPA01_REG_B6CTRL2 + (num - 6) * 2, \
.vsel_mask = S2MPA01_BUCK_VSEL_MASK, \
.enable_reg = S2MPA01_REG_B6CTRL1 + (num - 6) * 2, \
.enable_mask = S2MPA01_ENABLE_MASK \
}
#define regulator_desc_buck8 { \
.name = "BUCK8", \
.id = S2MPA01_BUCK8, \
.ops = &s2mpa01_buck_ops, \
.type = REGULATOR_VOLTAGE, \
.owner = THIS_MODULE, \
.min_uV = S2MPA01_BUCK_MIN2, \
.uV_step = S2MPA01_BUCK_STEP2, \
.n_voltages = S2MPA01_BUCK_N_VOLTAGES, \
.ramp_delay = S2MPA01_RAMP_DELAY, \
.vsel_reg = S2MPA01_REG_B8CTRL2, \
.vsel_mask = S2MPA01_BUCK_VSEL_MASK, \
.enable_reg = S2MPA01_REG_B8CTRL1, \
.enable_mask = S2MPA01_ENABLE_MASK \
}
#define regulator_desc_buck9 { \
.name = "BUCK9", \
.id = S2MPA01_BUCK9, \
.ops = &s2mpa01_buck_ops, \
.type = REGULATOR_VOLTAGE, \
.owner = THIS_MODULE, \
.min_uV = S2MPA01_BUCK_MIN4, \
.uV_step = S2MPA01_BUCK_STEP2, \
.n_voltages = S2MPA01_BUCK_N_VOLTAGES, \
.ramp_delay = S2MPA01_RAMP_DELAY, \
.vsel_reg = S2MPA01_REG_B9CTRL2, \
.vsel_mask = S2MPA01_BUCK_VSEL_MASK, \
.enable_reg = S2MPA01_REG_B9CTRL1, \
.enable_mask = S2MPA01_ENABLE_MASK \
}
#define regulator_desc_buck10 { \
.name = "BUCK10", \
.id = S2MPA01_BUCK10, \
.ops = &s2mpa01_buck_ops, \
.type = REGULATOR_VOLTAGE, \
.owner = THIS_MODULE, \
.min_uV = S2MPA01_BUCK_MIN3, \
.uV_step = S2MPA01_BUCK_STEP2, \
.n_voltages = S2MPA01_BUCK_N_VOLTAGES, \
.ramp_delay = S2MPA01_RAMP_DELAY, \
.vsel_reg = S2MPA01_REG_B10CTRL2, \
.vsel_mask = S2MPA01_BUCK_VSEL_MASK, \
.enable_reg = S2MPA01_REG_B10CTRL1, \
.enable_mask = S2MPA01_ENABLE_MASK \
}
static
struct
regulator_desc
regulators
[]
=
{
regulator_desc_ldo2
(
1
),
regulator_desc_ldo1
(
2
),
regulator_desc_ldo1
(
3
),
regulator_desc_ldo1
(
4
),
regulator_desc_ldo1
(
5
),
regulator_desc_ldo2
(
6
),
regulator_desc_ldo1
(
7
),
regulator_desc_ldo1
(
8
),
regulator_desc_ldo1
(
9
),
regulator_desc_ldo1
(
10
),
regulator_desc_ldo2
(
11
),
regulator_desc_ldo1
(
12
),
regulator_desc_ldo1
(
13
),
regulator_desc_ldo1
(
14
),
regulator_desc_ldo1
(
15
),
regulator_desc_ldo1
(
16
),
regulator_desc_ldo1
(
17
),
regulator_desc_ldo1
(
18
),
regulator_desc_ldo1
(
19
),
regulator_desc_ldo1
(
20
),
regulator_desc_ldo1
(
21
),
regulator_desc_ldo2
(
22
),
regulator_desc_ldo2
(
23
),
regulator_desc_ldo1
(
24
),
regulator_desc_ldo1
(
25
),
regulator_desc_ldo1
(
26
),
regulator_desc_buck1_4
(
1
),
regulator_desc_buck1_4
(
2
),
regulator_desc_buck1_4
(
3
),
regulator_desc_buck1_4
(
4
),
regulator_desc_buck5
,
regulator_desc_buck6_7
(
6
),
regulator_desc_buck6_7
(
7
),
regulator_desc_buck8
,
regulator_desc_buck9
,
regulator_desc_buck10
,
};
static
int
s2mpa01_pmic_probe
(
struct
platform_device
*
pdev
)
{
struct
sec_pmic_dev
*
iodev
=
dev_get_drvdata
(
pdev
->
dev
.
parent
);
struct
sec_platform_data
*
pdata
=
dev_get_platdata
(
iodev
->
dev
);
struct
of_regulator_match
rdata
[
S2MPA01_REGULATOR_MAX
];
struct
device_node
*
reg_np
=
NULL
;
struct
regulator_config
config
=
{
};
struct
s2mpa01_info
*
s2mpa01
;
int
i
;
s2mpa01
=
devm_kzalloc
(
&
pdev
->
dev
,
sizeof
(
*
s2mpa01
),
GFP_KERNEL
);
if
(
!
s2mpa01
)
return
-
ENOMEM
;
for
(
i
=
0
;
i
<
S2MPA01_REGULATOR_CNT
;
i
++
)
rdata
[
i
].
name
=
regulators
[
i
].
name
;
if
(
iodev
->
dev
->
of_node
)
{
reg_np
=
of_get_child_by_name
(
iodev
->
dev
->
of_node
,
"regulators"
);
if
(
!
reg_np
)
{
dev_err
(
&
pdev
->
dev
,
"could not find regulators sub-node
\n
"
);
return
-
EINVAL
;
}
of_regulator_match
(
&
pdev
->
dev
,
reg_np
,
rdata
,
S2MPA01_REGULATOR_MAX
);
of_node_put
(
reg_np
);
}
platform_set_drvdata
(
pdev
,
s2mpa01
);
config
.
dev
=
&
pdev
->
dev
;
config
.
regmap
=
iodev
->
regmap_pmic
;
config
.
driver_data
=
s2mpa01
;
for
(
i
=
0
;
i
<
S2MPA01_REGULATOR_MAX
;
i
++
)
{
struct
regulator_dev
*
rdev
;
if
(
pdata
)
config
.
init_data
=
pdata
->
regulators
[
i
].
initdata
;
else
config
.
init_data
=
rdata
[
i
].
init_data
;
if
(
reg_np
)
config
.
of_node
=
rdata
[
i
].
of_node
;
rdev
=
devm_regulator_register
(
&
pdev
->
dev
,
&
regulators
[
i
],
&
config
);
if
(
IS_ERR
(
rdev
))
{
dev_err
(
&
pdev
->
dev
,
"regulator init failed for %d
\n
"
,
i
);
return
PTR_ERR
(
rdev
);
}
}
return
0
;
}
static
const
struct
platform_device_id
s2mpa01_pmic_id
[]
=
{
{
"s2mpa01-pmic"
,
0
},
{
},
};
MODULE_DEVICE_TABLE
(
platform
,
s2mpa01_pmic_id
);
static
struct
platform_driver
s2mpa01_pmic_driver
=
{
.
driver
=
{
.
name
=
"s2mpa01-pmic"
,
.
owner
=
THIS_MODULE
,
},
.
probe
=
s2mpa01_pmic_probe
,
.
id_table
=
s2mpa01_pmic_id
,
};
module_platform_driver
(
s2mpa01_pmic_driver
);
/* Module information */
MODULE_AUTHOR
(
"Sangbeom Kim <sbkim73@samsung.com>"
);
MODULE_AUTHOR
(
"Sachin Kamat <sachin.kamat@samsung.com>"
);
MODULE_DESCRIPTION
(
"SAMSUNG S2MPA01 Regulator Driver"
);
MODULE_LICENSE
(
"GPL"
);
include/linux/mfd/samsung/core.h
View file @
507792c9
...
...
@@ -18,7 +18,9 @@ enum sec_device_type {
S5M8751X
,
S5M8763X
,
S5M8767X
,
S2MPA01
,
S2MPS11X
,
S2MPS14X
,
};
/**
...
...
@@ -50,7 +52,7 @@ struct sec_pmic_dev {
struct
regmap_irq_chip_data
*
irq_data
;
int
ono
;
int
type
;
unsigned
long
type
;
bool
wakeup
;
bool
wtsr_smpl
;
};
...
...
@@ -100,7 +102,12 @@ struct sec_platform_data {
int
buck16_ramp_delay
;
int
buck7810_ramp_delay
;
int
buck9_ramp_delay
;
int
buck24_ramp_delay
;
int
buck3_ramp_delay
;
int
buck7_ramp_delay
;
int
buck8910_ramp_delay
;
bool
buck1_ramp_enable
;
bool
buck2_ramp_enable
;
bool
buck3_ramp_enable
;
bool
buck4_ramp_enable
;
...
...
include/linux/mfd/samsung/irq.h
View file @
507792c9
...
...
@@ -13,6 +13,56 @@
#ifndef __LINUX_MFD_SEC_IRQ_H
#define __LINUX_MFD_SEC_IRQ_H
enum
s2mpa01_irq
{
S2MPA01_IRQ_PWRONF
,
S2MPA01_IRQ_PWRONR
,
S2MPA01_IRQ_JIGONBF
,
S2MPA01_IRQ_JIGONBR
,
S2MPA01_IRQ_ACOKBF
,
S2MPA01_IRQ_ACOKBR
,
S2MPA01_IRQ_PWRON1S
,
S2MPA01_IRQ_MRB
,
S2MPA01_IRQ_RTC60S
,
S2MPA01_IRQ_RTCA1
,
S2MPA01_IRQ_RTCA0
,
S2MPA01_IRQ_SMPL
,
S2MPA01_IRQ_RTC1S
,
S2MPA01_IRQ_WTSR
,
S2MPA01_IRQ_INT120C
,
S2MPA01_IRQ_INT140C
,
S2MPA01_IRQ_LDO3_TSD
,
S2MPA01_IRQ_B16_TSD
,
S2MPA01_IRQ_B24_TSD
,
S2MPA01_IRQ_B35_TSD
,
S2MPA01_IRQ_NR
,
};
#define S2MPA01_IRQ_PWRONF_MASK (1 << 0)
#define S2MPA01_IRQ_PWRONR_MASK (1 << 1)
#define S2MPA01_IRQ_JIGONBF_MASK (1 << 2)
#define S2MPA01_IRQ_JIGONBR_MASK (1 << 3)
#define S2MPA01_IRQ_ACOKBF_MASK (1 << 4)
#define S2MPA01_IRQ_ACOKBR_MASK (1 << 5)
#define S2MPA01_IRQ_PWRON1S_MASK (1 << 6)
#define S2MPA01_IRQ_MRB_MASK (1 << 7)
#define S2MPA01_IRQ_RTC60S_MASK (1 << 0)
#define S2MPA01_IRQ_RTCA1_MASK (1 << 1)
#define S2MPA01_IRQ_RTCA0_MASK (1 << 2)
#define S2MPA01_IRQ_SMPL_MASK (1 << 3)
#define S2MPA01_IRQ_RTC1S_MASK (1 << 4)
#define S2MPA01_IRQ_WTSR_MASK (1 << 5)
#define S2MPA01_IRQ_INT120C_MASK (1 << 0)
#define S2MPA01_IRQ_INT140C_MASK (1 << 1)
#define S2MPA01_IRQ_LDO3_TSD_MASK (1 << 2)
#define S2MPA01_IRQ_B16_TSD_MASK (1 << 3)
#define S2MPA01_IRQ_B24_TSD_MASK (1 << 4)
#define S2MPA01_IRQ_B35_TSD_MASK (1 << 5)
enum
s2mps11_irq
{
S2MPS11_IRQ_PWRONF
,
S2MPS11_IRQ_PWRONR
,
...
...
@@ -24,8 +74,8 @@ enum s2mps11_irq {
S2MPS11_IRQ_MRB
,
S2MPS11_IRQ_RTC60S
,
S2MPS11_IRQ_RTCA0
,
S2MPS11_IRQ_RTCA1
,
S2MPS11_IRQ_RTCA2
,
S2MPS11_IRQ_SMPL
,
S2MPS11_IRQ_RTC1S
,
S2MPS11_IRQ_WTSR
,
...
...
@@ -47,7 +97,7 @@ enum s2mps11_irq {
#define S2MPS11_IRQ_RTC60S_MASK (1 << 0)
#define S2MPS11_IRQ_RTCA1_MASK (1 << 1)
#define S2MPS11_IRQ_RTCA
2
_MASK (1 << 2)
#define S2MPS11_IRQ_RTCA
0
_MASK (1 << 2)
#define S2MPS11_IRQ_SMPL_MASK (1 << 3)
#define S2MPS11_IRQ_RTC1S_MASK (1 << 4)
#define S2MPS11_IRQ_WTSR_MASK (1 << 5)
...
...
@@ -55,6 +105,33 @@ enum s2mps11_irq {
#define S2MPS11_IRQ_INT120C_MASK (1 << 0)
#define S2MPS11_IRQ_INT140C_MASK (1 << 1)
enum
s2mps14_irq
{
S2MPS14_IRQ_PWRONF
,
S2MPS14_IRQ_PWRONR
,
S2MPS14_IRQ_JIGONBF
,
S2MPS14_IRQ_JIGONBR
,
S2MPS14_IRQ_ACOKBF
,
S2MPS14_IRQ_ACOKBR
,
S2MPS14_IRQ_PWRON1S
,
S2MPS14_IRQ_MRB
,
S2MPS14_IRQ_RTC60S
,
S2MPS14_IRQ_RTCA1
,
S2MPS14_IRQ_RTCA0
,
S2MPS14_IRQ_SMPL
,
S2MPS14_IRQ_RTC1S
,
S2MPS14_IRQ_WTSR
,
S2MPS14_IRQ_INT120C
,
S2MPS14_IRQ_INT140C
,
S2MPS14_IRQ_TSD
,
S2MPS14_IRQ_NR
,
};
/* Masks for interrupts are the same as in s2mps11 */
#define S2MPS14_IRQ_TSD_MASK (1 << 2)
enum
s5m8767_irq
{
S5M8767_IRQ_PWRR
,
S5M8767_IRQ_PWRF
,
...
...
include/linux/mfd/samsung/rtc.h
View file @
507792c9
/* rtc.h
*
* Copyright (c) 2011 Samsung Electronics Co., Ltd
* Copyright (c) 2011
-2014
Samsung Electronics Co., Ltd
* http://www.samsung.com
*
* This program is free software; you can redistribute it and/or modify it
...
...
@@ -8,6 +8,11 @@
* 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.
*
*/
#ifndef __LINUX_MFD_SEC_RTC_H
...
...
@@ -43,6 +48,39 @@ enum sec_rtc_reg {
SEC_RTC_STATUS
,
SEC_WTSR_SMPL_CNTL
,
SEC_RTC_UDR_CON
,
SEC_RTC_REG_MAX
,
};
enum
s2mps_rtc_reg
{
S2MPS_RTC_CTRL
,
S2MPS_WTSR_SMPL_CNTL
,
S2MPS_RTC_UDR_CON
,
S2MPS_RSVD
,
S2MPS_RTC_SEC
,
S2MPS_RTC_MIN
,
S2MPS_RTC_HOUR
,
S2MPS_RTC_WEEKDAY
,
S2MPS_RTC_DATE
,
S2MPS_RTC_MONTH
,
S2MPS_RTC_YEAR
,
S2MPS_ALARM0_SEC
,
S2MPS_ALARM0_MIN
,
S2MPS_ALARM0_HOUR
,
S2MPS_ALARM0_WEEKDAY
,
S2MPS_ALARM0_DATE
,
S2MPS_ALARM0_MONTH
,
S2MPS_ALARM0_YEAR
,
S2MPS_ALARM1_SEC
,
S2MPS_ALARM1_MIN
,
S2MPS_ALARM1_HOUR
,
S2MPS_ALARM1_WEEKDAY
,
S2MPS_ALARM1_DATE
,
S2MPS_ALARM1_MONTH
,
S2MPS_ALARM1_YEAR
,
S2MPS_OFFSRC
,
S2MPS_RTC_REG_MAX
,
};
#define RTC_I2C_ADDR (0x0C >> 1)
...
...
@@ -54,6 +92,9 @@ enum sec_rtc_reg {
#define ALARM1_STATUS (1 << 2)
#define UPDATE_AD (1 << 0)
#define S2MPS_ALARM0_STATUS (1 << 2)
#define S2MPS_ALARM1_STATUS (1 << 1)
/* RTC Control Register */
#define BCD_EN_SHIFT 0
#define BCD_EN_MASK (1 << BCD_EN_SHIFT)
...
...
@@ -62,6 +103,10 @@ enum sec_rtc_reg {
/* RTC Update Register1 */
#define RTC_UDR_SHIFT 0
#define RTC_UDR_MASK (1 << RTC_UDR_SHIFT)
#define S2MPS_RTC_WUDR_SHIFT 4
#define S2MPS_RTC_WUDR_MASK (1 << S2MPS_RTC_WUDR_SHIFT)
#define S2MPS_RTC_RUDR_SHIFT 0
#define S2MPS_RTC_RUDR_MASK (1 << S2MPS_RTC_RUDR_SHIFT)
#define RTC_TCON_SHIFT 1
#define RTC_TCON_MASK (1 << RTC_TCON_SHIFT)
#define RTC_TIME_EN_SHIFT 3
...
...
include/linux/mfd/samsung/s2mpa01.h
0 → 100644
View file @
507792c9
/*
* Copyright (c) 2013 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_S2MPA01_H
#define __LINUX_MFD_S2MPA01_H
/* S2MPA01 registers */
enum
s2mpa01_reg
{
S2MPA01_REG_ID
,
S2MPA01_REG_INT1
,
S2MPA01_REG_INT2
,
S2MPA01_REG_INT3
,
S2MPA01_REG_INT1M
,
S2MPA01_REG_INT2M
,
S2MPA01_REG_INT3M
,
S2MPA01_REG_ST1
,
S2MPA01_REG_ST2
,
S2MPA01_REG_PWRONSRC
,
S2MPA01_REG_OFFSRC
,
S2MPA01_REG_RTC_BUF
,
S2MPA01_REG_CTRL1
,
S2MPA01_REG_ETC_TEST
,
S2MPA01_REG_RSVD1
,
S2MPA01_REG_BU_CHG
,
S2MPA01_REG_RAMP1
,
S2MPA01_REG_RAMP2
,
S2MPA01_REG_LDO_DSCH1
,
S2MPA01_REG_LDO_DSCH2
,
S2MPA01_REG_LDO_DSCH3
,
S2MPA01_REG_LDO_DSCH4
,
S2MPA01_REG_OTP_ADRL
,
S2MPA01_REG_OTP_ADRH
,
S2MPA01_REG_OTP_DATA
,
S2MPA01_REG_MON1SEL
,
S2MPA01_REG_MON2SEL
,
S2MPA01_REG_LEE
,
S2MPA01_REG_RSVD2
,
S2MPA01_REG_RSVD3
,
S2MPA01_REG_RSVD4
,
S2MPA01_REG_RSVD5
,
S2MPA01_REG_RSVD6
,
S2MPA01_REG_TOP_RSVD
,
S2MPA01_REG_DVS_SEL
,
S2MPA01_REG_DVS_PTR
,
S2MPA01_REG_DVS_DATA
,
S2MPA01_REG_RSVD_NO
,
S2MPA01_REG_UVLO
,
S2MPA01_REG_LEE_NO
,
S2MPA01_REG_B1CTRL1
,
S2MPA01_REG_B1CTRL2
,
S2MPA01_REG_B2CTRL1
,
S2MPA01_REG_B2CTRL2
,
S2MPA01_REG_B3CTRL1
,
S2MPA01_REG_B3CTRL2
,
S2MPA01_REG_B4CTRL1
,
S2MPA01_REG_B4CTRL2
,
S2MPA01_REG_B5CTRL1
,
S2MPA01_REG_B5CTRL2
,
S2MPA01_REG_B5CTRL3
,
S2MPA01_REG_B5CTRL4
,
S2MPA01_REG_B5CTRL5
,
S2MPA01_REG_B5CTRL6
,
S2MPA01_REG_B6CTRL1
,
S2MPA01_REG_B6CTRL2
,
S2MPA01_REG_B7CTRL1
,
S2MPA01_REG_B7CTRL2
,
S2MPA01_REG_B8CTRL1
,
S2MPA01_REG_B8CTRL2
,
S2MPA01_REG_B9CTRL1
,
S2MPA01_REG_B9CTRL2
,
S2MPA01_REG_B10CTRL1
,
S2MPA01_REG_B10CTRL2
,
S2MPA01_REG_L1CTRL
,
S2MPA01_REG_L2CTRL
,
S2MPA01_REG_L3CTRL
,
S2MPA01_REG_L4CTRL
,
S2MPA01_REG_L5CTRL
,
S2MPA01_REG_L6CTRL
,
S2MPA01_REG_L7CTRL
,
S2MPA01_REG_L8CTRL
,
S2MPA01_REG_L9CTRL
,
S2MPA01_REG_L10CTRL
,
S2MPA01_REG_L11CTRL
,
S2MPA01_REG_L12CTRL
,
S2MPA01_REG_L13CTRL
,
S2MPA01_REG_L14CTRL
,
S2MPA01_REG_L15CTRL
,
S2MPA01_REG_L16CTRL
,
S2MPA01_REG_L17CTRL
,
S2MPA01_REG_L18CTRL
,
S2MPA01_REG_L19CTRL
,
S2MPA01_REG_L20CTRL
,
S2MPA01_REG_L21CTRL
,
S2MPA01_REG_L22CTRL
,
S2MPA01_REG_L23CTRL
,
S2MPA01_REG_L24CTRL
,
S2MPA01_REG_L25CTRL
,
S2MPA01_REG_L26CTRL
,
S2MPA01_REG_LDO_OVCB1
,
S2MPA01_REG_LDO_OVCB2
,
S2MPA01_REG_LDO_OVCB3
,
S2MPA01_REG_LDO_OVCB4
,
};
/* S2MPA01 regulator ids */
enum
s2mpa01_regulators
{
S2MPA01_LDO1
,
S2MPA01_LDO2
,
S2MPA01_LDO3
,
S2MPA01_LDO4
,
S2MPA01_LDO5
,
S2MPA01_LDO6
,
S2MPA01_LDO7
,
S2MPA01_LDO8
,
S2MPA01_LDO9
,
S2MPA01_LDO10
,
S2MPA01_LDO11
,
S2MPA01_LDO12
,
S2MPA01_LDO13
,
S2MPA01_LDO14
,
S2MPA01_LDO15
,
S2MPA01_LDO16
,
S2MPA01_LDO17
,
S2MPA01_LDO18
,
S2MPA01_LDO19
,
S2MPA01_LDO20
,
S2MPA01_LDO21
,
S2MPA01_LDO22
,
S2MPA01_LDO23
,
S2MPA01_LDO24
,
S2MPA01_LDO25
,
S2MPA01_LDO26
,
S2MPA01_BUCK1
,
S2MPA01_BUCK2
,
S2MPA01_BUCK3
,
S2MPA01_BUCK4
,
S2MPA01_BUCK5
,
S2MPA01_BUCK6
,
S2MPA01_BUCK7
,
S2MPA01_BUCK8
,
S2MPA01_BUCK9
,
S2MPA01_BUCK10
,
S2MPA01_REGULATOR_MAX
,
};
#define S2MPA01_BUCK_MIN1 600000
#define S2MPA01_BUCK_MIN2 800000
#define S2MPA01_BUCK_MIN3 1000000
#define S2MPA01_BUCK_MIN4 1500000
#define S2MPA01_LDO_MIN 800000
#define S2MPA01_BUCK_STEP1 6250
#define S2MPA01_BUCK_STEP2 12500
#define S2MPA01_LDO_STEP1 50000
#define S2MPA01_LDO_STEP2 25000
#define S2MPA01_LDO_VSEL_MASK 0x3F
#define S2MPA01_BUCK_VSEL_MASK 0xFF
#define S2MPA01_ENABLE_MASK (0x03 << S2MPA01_ENABLE_SHIFT)
#define S2MPA01_ENABLE_SHIFT 0x06
#define S2MPA01_LDO_N_VOLTAGES (S2MPA01_LDO_VSEL_MASK + 1)
#define S2MPA01_BUCK_N_VOLTAGES (S2MPA01_BUCK_VSEL_MASK + 1)
#define S2MPA01_RAMP_DELAY 12500
/* uV/us */
#define S2MPA01_BUCK16_RAMP_SHIFT 4
#define S2MPA01_BUCK24_RAMP_SHIFT 6
#define S2MPA01_BUCK3_RAMP_SHIFT 4
#define S2MPA01_BUCK5_RAMP_SHIFT 6
#define S2MPA01_BUCK7_RAMP_SHIFT 2
#define S2MPA01_BUCK8910_RAMP_SHIFT 0
#define S2MPA01_BUCK1_RAMP_EN_SHIFT 3
#define S2MPA01_BUCK2_RAMP_EN_SHIFT 2
#define S2MPA01_BUCK3_RAMP_EN_SHIFT 1
#define S2MPA01_BUCK4_RAMP_EN_SHIFT 0
#define S2MPA01_PMIC_EN_SHIFT 6
#endif
/*__LINUX_MFD_S2MPA01_H */
include/linux/mfd/samsung/s2mps14.h
0 → 100644
View file @
507792c9
/*
* s2mps14.h
*
* Copyright (c) 2014 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.
*
* 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.
*
*/
#ifndef __LINUX_MFD_S2MPS14_H
#define __LINUX_MFD_S2MPS14_H
/* S2MPS14 registers */
enum
s2mps14_reg
{
S2MPS14_REG_ID
,
S2MPS14_REG_INT1
,
S2MPS14_REG_INT2
,
S2MPS14_REG_INT3
,
S2MPS14_REG_INT1M
,
S2MPS14_REG_INT2M
,
S2MPS14_REG_INT3M
,
S2MPS14_REG_ST1
,
S2MPS14_REG_ST2
,
S2MPS14_REG_PWRONSRC
,
S2MPS14_REG_OFFSRC
,
S2MPS14_REG_BU_CHG
,
S2MPS14_REG_RTCCTRL
,
S2MPS14_REG_CTRL1
,
S2MPS14_REG_CTRL2
,
S2MPS14_REG_RSVD1
,
S2MPS14_REG_RSVD2
,
S2MPS14_REG_RSVD3
,
S2MPS14_REG_RSVD4
,
S2MPS14_REG_RSVD5
,
S2MPS14_REG_RSVD6
,
S2MPS14_REG_CTRL3
,
S2MPS14_REG_RSVD7
,
S2MPS14_REG_RSVD8
,
S2MPS14_REG_WRSTBI
,
S2MPS14_REG_B1CTRL1
,
S2MPS14_REG_B1CTRL2
,
S2MPS14_REG_B2CTRL1
,
S2MPS14_REG_B2CTRL2
,
S2MPS14_REG_B3CTRL1
,
S2MPS14_REG_B3CTRL2
,
S2MPS14_REG_B4CTRL1
,
S2MPS14_REG_B4CTRL2
,
S2MPS14_REG_B5CTRL1
,
S2MPS14_REG_B5CTRL2
,
S2MPS14_REG_L1CTRL
,
S2MPS14_REG_L2CTRL
,
S2MPS14_REG_L3CTRL
,
S2MPS14_REG_L4CTRL
,
S2MPS14_REG_L5CTRL
,
S2MPS14_REG_L6CTRL
,
S2MPS14_REG_L7CTRL
,
S2MPS14_REG_L8CTRL
,
S2MPS14_REG_L9CTRL
,
S2MPS14_REG_L10CTRL
,
S2MPS14_REG_L11CTRL
,
S2MPS14_REG_L12CTRL
,
S2MPS14_REG_L13CTRL
,
S2MPS14_REG_L14CTRL
,
S2MPS14_REG_L15CTRL
,
S2MPS14_REG_L16CTRL
,
S2MPS14_REG_L17CTRL
,
S2MPS14_REG_L18CTRL
,
S2MPS14_REG_L19CTRL
,
S2MPS14_REG_L20CTRL
,
S2MPS14_REG_L21CTRL
,
S2MPS14_REG_L22CTRL
,
S2MPS14_REG_L23CTRL
,
S2MPS14_REG_L24CTRL
,
S2MPS14_REG_L25CTRL
,
S2MPS14_REG_LDODSCH1
,
S2MPS14_REG_LDODSCH2
,
S2MPS14_REG_LDODSCH3
,
};
/* S2MPS14 regulator ids */
enum
s2mps14_regulators
{
S2MPS14_LDO1
,
S2MPS14_LDO2
,
S2MPS14_LDO3
,
S2MPS14_LDO4
,
S2MPS14_LDO5
,
S2MPS14_LDO6
,
S2MPS14_LDO7
,
S2MPS14_LDO8
,
S2MPS14_LDO9
,
S2MPS14_LDO10
,
S2MPS14_LDO11
,
S2MPS14_LDO12
,
S2MPS14_LDO13
,
S2MPS14_LDO14
,
S2MPS14_LDO15
,
S2MPS14_LDO16
,
S2MPS14_LDO17
,
S2MPS14_LDO18
,
S2MPS14_LDO19
,
S2MPS14_LDO20
,
S2MPS14_LDO21
,
S2MPS14_LDO22
,
S2MPS14_LDO23
,
S2MPS14_LDO24
,
S2MPS14_LDO25
,
S2MPS14_BUCK1
,
S2MPS14_BUCK2
,
S2MPS14_BUCK3
,
S2MPS14_BUCK4
,
S2MPS14_BUCK5
,
S2MPS14_REGULATOR_MAX
,
};
/* Regulator constraints for BUCKx */
#define S2MPS14_BUCK1235_MIN_600MV 600000
#define S2MPS14_BUCK4_MIN_1400MV 1400000
#define S2MPS14_BUCK1235_STEP_6_25MV 6250
#define S2MPS14_BUCK4_STEP_12_5MV 12500
#define S2MPS14_BUCK1235_START_SEL 0x20
#define S2MPS14_BUCK4_START_SEL 0x40
/*
* Default ramp delay in uv/us. Datasheet says that ramp delay can be
* controlled however it does not specify which register is used for that.
* Let's assume that default value will be set.
*/
#define S2MPS14_BUCK_RAMP_DELAY 12500
/* Regulator constraints for different types of LDOx */
#define S2MPS14_LDO_MIN_800MV 800000
#define S2MPS14_LDO_MIN_1800MV 1800000
#define S2MPS14_LDO_STEP_12_5MV 12500
#define S2MPS14_LDO_STEP_25MV 25000
#define S2MPS14_LDO_VSEL_MASK 0x3F
#define S2MPS14_BUCK_VSEL_MASK 0xFF
#define S2MPS14_ENABLE_MASK (0x03 << S2MPS14_ENABLE_SHIFT)
#define S2MPS14_ENABLE_SHIFT 6
#define S2MPS14_LDO_N_VOLTAGES (S2MPS14_LDO_VSEL_MASK + 1)
#define S2MPS14_BUCK_N_VOLTAGES (S2MPS14_BUCK_VSEL_MASK + 1)
#endif
/* __LINUX_MFD_S2MPS14_H */
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment