Commit 1044c180 authored by Mark Brown's avatar Mark Brown

regmap: Add hook for printk logging for debugging during early init

Sometimes for failures during very early init the trace infrastructure
isn't available early enough to be used.  For this sort of problem
defining LOG_DEVICE will add printks for basic register I/O on a specific
device, allowing trace to be extracted when the trace system doesn't come
up early enough to work with.
Signed-off-by: default avatarMark Brown <broonie@opensource.wolfsonmicro.com>
parent e8790ab4
...@@ -21,6 +21,18 @@ ...@@ -21,6 +21,18 @@
#include "internal.h" #include "internal.h"
/*
* Sometimes for failures during very early init the trace
* infrastructure isn't available early enough to be used. For this
* sort of problem defining LOG_DEVICE will add printks for basic
* register I/O on a specific device.
*/
#undef LOG_DEVICE
static int _regmap_update_bits(struct regmap *map, unsigned int reg,
unsigned int mask, unsigned int val,
bool *change);
bool regmap_writeable(struct regmap *map, unsigned int reg) bool regmap_writeable(struct regmap *map, unsigned int reg)
{ {
if (map->max_register && reg > map->max_register) if (map->max_register && reg > map->max_register)
...@@ -700,6 +712,11 @@ int _regmap_write(struct regmap *map, unsigned int reg, ...@@ -700,6 +712,11 @@ int _regmap_write(struct regmap *map, unsigned int reg,
} }
} }
#ifdef LOG_DEVICE
if (strcmp(dev_name(map->dev), LOG_DEVICE) == 0)
dev_info(map->dev, "%x <= %x\n", reg, val);
#endif
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) {
...@@ -903,6 +920,12 @@ static int _regmap_read(struct regmap *map, unsigned int reg, ...@@ -903,6 +920,12 @@ static int _regmap_read(struct regmap *map, unsigned int reg,
ret = _regmap_raw_read(map, reg, map->work_buf, map->format.val_bytes); ret = _regmap_raw_read(map, reg, map->work_buf, map->format.val_bytes);
if (ret == 0) { if (ret == 0) {
*val = map->format.parse_val(map->work_buf); *val = map->format.parse_val(map->work_buf);
#ifdef LOG_DEVICE
if (strcmp(dev_name(map->dev), LOG_DEVICE) == 0)
dev_info(map->dev, "%x => %x\n", reg, *val);
#endif
trace_regmap_reg_read(map->dev, reg, *val); trace_regmap_reg_read(map->dev, reg, *val);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment