]> git.itanic.dy.fi Git - linux-stable/commit
ARM: at91: pm: fix self-refresh for sama7g5
authorClaudiu Beznea <claudiu.beznea@microchip.com>
Fri, 26 Aug 2022 08:39:20 +0000 (11:39 +0300)
committerClaudiu Beznea <claudiu.beznea@microchip.com>
Wed, 31 Aug 2022 07:27:57 +0000 (10:27 +0300)
commita02875c4cbd6f3d2f33d70cc158a19ef02d4b84f
treeb535c15dc44af5758e70a53d16a7896b41eb6a0b
parentf04445fa099668ca1c9889c48e309f49740f92f0
ARM: at91: pm: fix self-refresh for sama7g5

It has been discovered that on some parts, from time to time, self-refresh
procedure doesn't work as expected. Debugging and investigating it proved
that disabling AC DLL introduce glitches in RAM controllers which
leads to unexpected behavior. This is confirmed as a hardware bug. DLL
bypass disables 3 DLLs: 2 DX DLLs and AC DLL. Thus, keep only DX DLLs
disabled. This introduce 6mA extra current consumption on VDDCORE when
switching to any ULP mode or standby mode but the self-refresh procedure
still works.

Fixes: f0bbf17958e8 ("ARM: at91: pm: add self-refresh support for sama7g5")
Suggested-by: Frederic Schumacher <frederic.schumacher@microchip.com>
Signed-off-by: Claudiu Beznea <claudiu.beznea@microchip.com>
Tested-by: Cristian Birsan <cristian.birsan@microchip.com>
Link: https://lore.kernel.org/r/20220826083927.3107272-3-claudiu.beznea@microchip.com
arch/arm/mach-at91/pm_suspend.S
include/soc/at91/sama7-ddr.h