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
b67a2ecb
Commit
b67a2ecb
authored
Feb 19, 2013
by
Mark Brown
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'regulator/topic/tps51632' into regulator-next
parents
178a097d
d94d9aca
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
130 additions
and
49 deletions
+130
-49
Documentation/devicetree/bindings/regulator/tps51632-regulator.txt
...tion/devicetree/bindings/regulator/tps51632-regulator.txt
+27
-0
drivers/regulator/tps51632-regulator.c
drivers/regulator/tps51632-regulator.c
+103
-49
No files found.
Documentation/devicetree/bindings/regulator/tps51632-regulator.txt
0 → 100644
View file @
b67a2ecb
TPS51632 Voltage regulators
Required properties:
- compatible: Must be "ti,tps51632"
- reg: I2C slave address
Optional properties:
- ti,enable-pwm-dvfs: Enable the DVFS voltage control through the PWM interface.
- ti,dvfs-step-20mV: The 20mV step voltage when PWM DVFS enabled. Missing this
will set 10mV step voltage in PWM DVFS mode. In normal mode, the voltage
step is 10mV as per datasheet.
Any property defined as part of the core regulator binding, defined in
regulator.txt, can also be used.
Example:
tps51632 {
compatible = "ti,tps51632";
reg = <0x43>;
regulator-name = "tps51632-vout";
regulator-min-microvolt = <500000>;
regulator-max-microvolt = <1500000>;
regulator-boot-on;
ti,enable-pwm-dvfs;
ti,dvfs-step-20mV;
};
drivers/regulator/tps51632-regulator.c
View file @
b67a2ecb
...
...
@@ -28,10 +28,13 @@
#include <linux/init.h>
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/of.h>
#include <linux/of_device.h>
#include <linux/platform_device.h>
#include <linux/regmap.h>
#include <linux/regulator/driver.h>
#include <linux/regulator/machine.h>
#include <linux/regulator/of_regulator.h>
#include <linux/regulator/tps51632-regulator.h>
#include <linux/slab.h>
...
...
@@ -85,49 +88,8 @@ struct tps51632_chip {
struct
regulator_desc
desc
;
struct
regulator_dev
*
rdev
;
struct
regmap
*
regmap
;
bool
enable_pwm_dvfs
;
};
static
int
tps51632_dcdc_get_voltage_sel
(
struct
regulator_dev
*
rdev
)
{
struct
tps51632_chip
*
tps
=
rdev_get_drvdata
(
rdev
);
unsigned
int
data
;
int
ret
;
unsigned
int
reg
=
TPS51632_VOLTAGE_SELECT_REG
;
int
vsel
;
if
(
tps
->
enable_pwm_dvfs
)
reg
=
TPS51632_VOLTAGE_BASE_REG
;
ret
=
regmap_read
(
tps
->
regmap
,
reg
,
&
data
);
if
(
ret
<
0
)
{
dev_err
(
tps
->
dev
,
"reg read failed, err %d
\n
"
,
ret
);
return
ret
;
}
vsel
=
data
&
TPS51632_VOUT_MASK
;
return
vsel
;
}
static
int
tps51632_dcdc_set_voltage_sel
(
struct
regulator_dev
*
rdev
,
unsigned
selector
)
{
struct
tps51632_chip
*
tps
=
rdev_get_drvdata
(
rdev
);
int
ret
;
unsigned
int
reg
=
TPS51632_VOLTAGE_SELECT_REG
;
if
(
tps
->
enable_pwm_dvfs
)
reg
=
TPS51632_VOLTAGE_BASE_REG
;
if
(
selector
>
TPS51632_MAX_VSEL
)
return
-
EINVAL
;
ret
=
regmap_write
(
tps
->
regmap
,
reg
,
selector
);
if
(
ret
<
0
)
dev_err
(
tps
->
dev
,
"reg write failed, err %d
\n
"
,
ret
);
return
ret
;
}
static
int
tps51632_dcdc_set_ramp_delay
(
struct
regulator_dev
*
rdev
,
int
ramp_delay
)
{
...
...
@@ -144,8 +106,8 @@ static int tps51632_dcdc_set_ramp_delay(struct regulator_dev *rdev,
}
static
struct
regulator_ops
tps51632_dcdc_ops
=
{
.
get_voltage_sel
=
tps51632_dcdc_get_voltage_sel
,
.
set_voltage_sel
=
tps51632_dcdc_set_voltage_sel
,
.
get_voltage_sel
=
regulator_get_voltage_sel_regmap
,
.
set_voltage_sel
=
regulator_set_voltage_sel_regmap
,
.
list_voltage
=
regulator_list_voltage_linear
,
.
set_voltage_time_sel
=
regulator_set_voltage_time_sel
,
.
set_ramp_delay
=
tps51632_dcdc_set_ramp_delay
,
...
...
@@ -162,7 +124,6 @@ static int tps51632_init_dcdc(struct tps51632_chip *tps,
goto
skip_pwm_config
;
control
|=
TPS51632_DVFS_PWMEN
;
tps
->
enable_pwm_dvfs
=
pdata
->
enable_pwm_dvfs
;
vsel
=
TPS51632_VOLT_VSEL
(
pdata
->
base_voltage_uV
);
ret
=
regmap_write
(
tps
->
regmap
,
TPS51632_VOLTAGE_BASE_REG
,
vsel
);
if
(
ret
<
0
)
{
...
...
@@ -205,22 +166,96 @@ static int tps51632_init_dcdc(struct tps51632_chip *tps,
return
ret
;
}
static
bool
rd_wr_reg
(
struct
device
*
dev
,
unsigned
int
reg
)
static
bool
is_volatile_reg
(
struct
device
*
dev
,
unsigned
int
reg
)
{
switch
(
reg
)
{
case
TPS51632_OFFSET_REG
:
case
TPS51632_FAULT_REG
:
case
TPS51632_IMON_REG
:
return
true
;
default:
return
false
;
}
}
static
bool
is_read_reg
(
struct
device
*
dev
,
unsigned
int
reg
)
{
if
((
reg
>=
0x8
)
&&
(
reg
<=
0x10
))
switch
(
reg
)
{
case
0x08
...
0x0F
:
return
false
;
default:
return
true
;
}
}
static
bool
is_write_reg
(
struct
device
*
dev
,
unsigned
int
reg
)
{
switch
(
reg
)
{
case
TPS51632_VOLTAGE_SELECT_REG
:
case
TPS51632_VOLTAGE_BASE_REG
:
case
TPS51632_VMAX_REG
:
case
TPS51632_DVFS_CONTROL_REG
:
case
TPS51632_POWER_STATE_REG
:
case
TPS51632_SLEW_REGS
:
return
true
;
default:
return
false
;
}
}
static
const
struct
regmap_config
tps51632_regmap_config
=
{
.
reg_bits
=
8
,
.
val_bits
=
8
,
.
writeable_reg
=
rd_wr_reg
,
.
readable_reg
=
rd_wr_reg
,
.
writeable_reg
=
is_write_reg
,
.
readable_reg
=
is_read_reg
,
.
volatile_reg
=
is_volatile_reg
,
.
max_register
=
TPS51632_MAX_REG
-
1
,
.
cache_type
=
REGCACHE_RBTREE
,
};
#if defined(CONFIG_OF)
static
const
struct
of_device_id
tps51632_of_match
[]
=
{
{
.
compatible
=
"ti,tps51632"
,},
{},
};
MODULE_DEVICE_TABLE
(
of
,
tps51632_of_match
);
static
struct
tps51632_regulator_platform_data
*
of_get_tps51632_platform_data
(
struct
device
*
dev
)
{
struct
tps51632_regulator_platform_data
*
pdata
;
struct
device_node
*
np
=
dev
->
of_node
;
pdata
=
devm_kzalloc
(
dev
,
sizeof
(
*
pdata
),
GFP_KERNEL
);
if
(
!
pdata
)
{
dev_err
(
dev
,
"Memory alloc failed for platform data
\n
"
);
return
NULL
;
}
pdata
->
reg_init_data
=
of_get_regulator_init_data
(
dev
,
dev
->
of_node
);
if
(
!
pdata
->
reg_init_data
)
{
dev_err
(
dev
,
"Not able to get OF regulator init data
\n
"
);
return
NULL
;
}
pdata
->
enable_pwm_dvfs
=
of_property_read_bool
(
np
,
"ti,enable-pwm-dvfs"
);
pdata
->
dvfs_step_20mV
=
of_property_read_bool
(
np
,
"ti,dvfs-step-20mV"
);
pdata
->
base_voltage_uV
=
pdata
->
reg_init_data
->
constraints
.
min_uV
?
:
TPS51632_MIN_VOLATGE
;
pdata
->
max_voltage_uV
=
pdata
->
reg_init_data
->
constraints
.
max_uV
?
:
TPS51632_MAX_VOLATGE
;
return
pdata
;
}
#else
static
struct
tps51632_regulator_platform_data
*
of_get_tps51632_platform_data
(
struct
device
*
dev
)
{
return
NULL
;
}
#endif
static
int
tps51632_probe
(
struct
i2c_client
*
client
,
const
struct
i2c_device_id
*
id
)
{
...
...
@@ -230,7 +265,19 @@ static int tps51632_probe(struct i2c_client *client,
int
ret
;
struct
regulator_config
config
=
{
};
if
(
client
->
dev
.
of_node
)
{
const
struct
of_device_id
*
match
;
match
=
of_match_device
(
of_match_ptr
(
tps51632_of_match
),
&
client
->
dev
);
if
(
!
match
)
{
dev_err
(
&
client
->
dev
,
"Error: No device match found
\n
"
);
return
-
ENODEV
;
}
}
pdata
=
client
->
dev
.
platform_data
;
if
(
!
pdata
&&
client
->
dev
.
of_node
)
pdata
=
of_get_tps51632_platform_data
(
&
client
->
dev
);
if
(
!
pdata
)
{
dev_err
(
&
client
->
dev
,
"No Platform data
\n
"
);
return
-
EINVAL
;
...
...
@@ -269,6 +316,12 @@ static int tps51632_probe(struct i2c_client *client,
tps
->
desc
.
type
=
REGULATOR_VOLTAGE
;
tps
->
desc
.
owner
=
THIS_MODULE
;
if
(
pdata
->
enable_pwm_dvfs
)
tps
->
desc
.
vsel_reg
=
TPS51632_VOLTAGE_BASE_REG
;
else
tps
->
desc
.
vsel_reg
=
TPS51632_VOLTAGE_SELECT_REG
;
tps
->
desc
.
vsel_mask
=
TPS51632_VOUT_MASK
;
tps
->
regmap
=
devm_regmap_init_i2c
(
client
,
&
tps51632_regmap_config
);
if
(
IS_ERR
(
tps
->
regmap
))
{
ret
=
PTR_ERR
(
tps
->
regmap
);
...
...
@@ -319,6 +372,7 @@ static struct i2c_driver tps51632_i2c_driver = {
.
driver
=
{
.
name
=
"tps51632"
,
.
owner
=
THIS_MODULE
,
.
of_match_table
=
of_match_ptr
(
tps51632_of_match
),
},
.
probe
=
tps51632_probe
,
.
remove
=
tps51632_remove
,
...
...
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