mirror of
https://github.com/rd-stuffs/msm-4.14.git
synced 2025-02-20 11:45:48 +08:00
regmap: Factor range lookup out of page selection
This will support a subsequent update to allow bulk writes to cross window boundaries. Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
This commit is contained in:
parent
4b020b3f9b
commit
98bc7dfd76
@ -765,17 +765,15 @@ struct regmap *dev_get_regmap(struct device *dev, const char *name)
|
|||||||
EXPORT_SYMBOL_GPL(dev_get_regmap);
|
EXPORT_SYMBOL_GPL(dev_get_regmap);
|
||||||
|
|
||||||
static int _regmap_select_page(struct regmap *map, unsigned int *reg,
|
static int _regmap_select_page(struct regmap *map, unsigned int *reg,
|
||||||
|
struct regmap_range_node *range,
|
||||||
unsigned int val_num)
|
unsigned int val_num)
|
||||||
{
|
{
|
||||||
struct regmap_range_node *range;
|
|
||||||
void *orig_work_buf;
|
void *orig_work_buf;
|
||||||
unsigned int win_offset;
|
unsigned int win_offset;
|
||||||
unsigned int win_page;
|
unsigned int win_page;
|
||||||
bool page_chg;
|
bool page_chg;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
range = _regmap_range_lookup(map, *reg);
|
|
||||||
if (range) {
|
|
||||||
win_offset = (*reg - range->range_min) % range->window_len;
|
win_offset = (*reg - range->range_min) % range->window_len;
|
||||||
win_page = (*reg - range->range_min) / range->window_len;
|
win_page = (*reg - range->range_min) / range->window_len;
|
||||||
|
|
||||||
@ -810,7 +808,6 @@ static int _regmap_select_page(struct regmap *map, unsigned int *reg,
|
|||||||
}
|
}
|
||||||
|
|
||||||
*reg = range->window_start + win_offset;
|
*reg = range->window_start + win_offset;
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -818,6 +815,7 @@ static int _regmap_select_page(struct regmap *map, unsigned int *reg,
|
|||||||
static int _regmap_raw_write(struct regmap *map, unsigned int reg,
|
static int _regmap_raw_write(struct regmap *map, unsigned int reg,
|
||||||
const void *val, size_t val_len)
|
const void *val, size_t val_len)
|
||||||
{
|
{
|
||||||
|
struct regmap_range_node *range;
|
||||||
u8 *u8 = map->work_buf;
|
u8 *u8 = map->work_buf;
|
||||||
void *buf;
|
void *buf;
|
||||||
int ret = -ENOTSUPP;
|
int ret = -ENOTSUPP;
|
||||||
@ -852,9 +850,13 @@ static int _regmap_raw_write(struct regmap *map, unsigned int reg,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = _regmap_select_page(map, ®, val_len / map->format.val_bytes);
|
range = _regmap_range_lookup(map, reg);
|
||||||
|
if (range) {
|
||||||
|
ret = _regmap_select_page(map, ®, range,
|
||||||
|
val_len / map->format.val_bytes);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
map->format.format_reg(map->work_buf, reg, map->reg_shift);
|
map->format.format_reg(map->work_buf, reg, map->reg_shift);
|
||||||
|
|
||||||
@ -903,6 +905,7 @@ static int _regmap_raw_write(struct regmap *map, unsigned int reg,
|
|||||||
int _regmap_write(struct regmap *map, unsigned int reg,
|
int _regmap_write(struct regmap *map, unsigned int reg,
|
||||||
unsigned int val)
|
unsigned int val)
|
||||||
{
|
{
|
||||||
|
struct regmap_range_node *range;
|
||||||
int ret;
|
int ret;
|
||||||
BUG_ON(!map->format.format_write && !map->format.format_val);
|
BUG_ON(!map->format.format_write && !map->format.format_val);
|
||||||
|
|
||||||
@ -924,9 +927,12 @@ int _regmap_write(struct regmap *map, unsigned int reg,
|
|||||||
trace_regmap_reg_write(map->dev, reg, val);
|
trace_regmap_reg_write(map->dev, reg, val);
|
||||||
|
|
||||||
if (map->format.format_write) {
|
if (map->format.format_write) {
|
||||||
ret = _regmap_select_page(map, ®, 1);
|
range = _regmap_range_lookup(map, reg);
|
||||||
|
if (range) {
|
||||||
|
ret = _regmap_select_page(map, ®, range, 1);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
map->format.format_write(map, reg, val);
|
map->format.format_write(map, reg, val);
|
||||||
|
|
||||||
@ -1082,12 +1088,17 @@ EXPORT_SYMBOL_GPL(regmap_bulk_write);
|
|||||||
static int _regmap_raw_read(struct regmap *map, unsigned int reg, void *val,
|
static int _regmap_raw_read(struct regmap *map, unsigned int reg, void *val,
|
||||||
unsigned int val_len)
|
unsigned int val_len)
|
||||||
{
|
{
|
||||||
|
struct regmap_range_node *range;
|
||||||
u8 *u8 = map->work_buf;
|
u8 *u8 = map->work_buf;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
ret = _regmap_select_page(map, ®, val_len / map->format.val_bytes);
|
range = _regmap_range_lookup(map, reg);
|
||||||
|
if (range) {
|
||||||
|
ret = _regmap_select_page(map, ®, range,
|
||||||
|
val_len / map->format.val_bytes);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
map->format.format_reg(map->work_buf, reg, map->reg_shift);
|
map->format.format_reg(map->work_buf, reg, map->reg_shift);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user