summaryrefslogtreecommitdiffstats
path: root/drivers/net/phy/phylink.c
diff options
context:
space:
mode:
authorCharles Keepax <ckeepax@opensource.cirrus.com>2023-06-01 12:10:36 +0200
committerMark Brown <broonie@kernel.org>2023-06-01 13:32:53 +0200
commit99e8dd39f34333d745e6c220be5d166e85214e6c (patch)
treed42eb7bac014213e3a19312b5d1b7b715093786c /drivers/net/phy/phylink.c
parentregmap: regmap-irq: Move handle_post_irq to before pm_runtime_put (diff)
downloadlinux-99e8dd39f34333d745e6c220be5d166e85214e6c.tar.xz
linux-99e8dd39f34333d745e6c220be5d166e85214e6c.zip
regmap: Add missing cache_only checks
The current behaviour around cache_only is slightly inconsistent, most paths will only check cache_only if cache_bypass is false, and will return -EBUSY if a read attempts to go to the hardware whilst cache_only is true. However, a couple of paths will not check cache_only at all. The most notable of these being regmap_raw_read which will check cache_only in the case it processes the transaction one register at a time, but not in the case it handles them as a block. In the typical case a device has been put into cache_only whilst powered down this can cause physical reads to happen whilst the device is unavailable. Add a check in regmap_raw_read and move the check in regmap_noinc_read, adding a check for cache_bypass, such that all paths are covered and consistent. Signed-off-by: Charles Keepax <ckeepax@opensource.cirrus.com> Link: https://lore.kernel.org/r/20230601101036.1499612-2-ckeepax@opensource.cirrus.com Signed-off-by: Mark Brown <broonie@kernel.org>
Diffstat (limited to 'drivers/net/phy/phylink.c')
0 files changed, 0 insertions, 0 deletions