mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-08 11:50:43 +09:00
UPSTREAM: regmap: fix deadlock on _regmap_raw_write() error path
Commit815806e39b("regmap: drop cache if the bus transfer error") added a call to regcache_drop_region() to error path in _regmap_raw_write(). However that path runs with regmap lock taken, and regcache_drop_region() tries to re-take it, causing a deadlock. Fix that by calling map->cache_ops->drop() directly. Change-Id: I55c6d3ed490c47e8b3f5ca774d051a700f707b6e Signed-off-by: Nikita Yushchenko <nikita.yoush@cogentembedded.com> Signed-off-by: Mark Brown <broonie@kernel.org> Signed-off-by: Huang, Tao <huangtao@rock-chips.com> (cherry picked from git.kernel.org broonie/regmap.git for-next commitf0aa1ce625)
This commit is contained in:
committed by
Huang, Tao
parent
60a514699d
commit
756d9ad548
@@ -1373,7 +1373,11 @@ int _regmap_raw_write(struct regmap *map, unsigned int reg,
|
||||
|
||||
kfree(buf);
|
||||
} else if (ret != 0 && !map->cache_bypass && map->format.parse_val) {
|
||||
regcache_drop_region(map, reg, reg + 1);
|
||||
/* regcache_drop_region() takes lock that we already have,
|
||||
* thus call map->cache_ops->drop() directly
|
||||
*/
|
||||
if (map->cache_ops && map->cache_ops->drop)
|
||||
map->cache_ops->drop(map, reg, reg + 1);
|
||||
}
|
||||
|
||||
trace_regmap_hw_write_done(map, reg, val_len / map->format.val_bytes);
|
||||
|
||||
Reference in New Issue
Block a user