ARM: at91: pm: fix DDR recalibration when resuming from backup and self-refresh
authorClaudiu Beznea <claudiu.beznea@microchip.com>
Fri, 26 Aug 2022 08:39:21 +0000 (11:39 +0300)
committerClaudiu Beznea <claudiu.beznea@microchip.com>
Wed, 31 Aug 2022 07:28:18 +0000 (10:28 +0300)
commit7a94b83a7dc551607b6c4400df29151e6a951f07
treeb10c9becc6b94ebf303853bad8918e79baff9a94
parenta02875c4cbd6f3d2f33d70cc158a19ef02d4b84f
ARM: at91: pm: fix DDR recalibration when resuming from backup and self-refresh

On SAMA7G5, when resuming from backup and self-refresh, the bootloader
performs DDR PHY recalibration by restoring the value of ZQ0SR0 (stored
in RAM by Linux before going to backup and self-refresh). It has been
discovered that the current procedure doesn't work for all possible values
that might go to ZQ0SR0 due to hardware bug. The workaround to this is to
avoid storing some values in ZQ0SR0. Thus Linux will read the ZQ0SR0
register and cache its value in RAM after processing it (using
modified_gray_code array). The bootloader will restore the processed value.

Fixes: d2d4716d8384 ("ARM: at91: pm: save ddr phy calibration data to securam")
Suggested-by: Frederic Schumacher <frederic.schumacher@microchip.com>
Signed-off-by: Claudiu Beznea <claudiu.beznea@microchip.com>
Link: https://lore.kernel.org/r/20220826083927.3107272-4-claudiu.beznea@microchip.com
arch/arm/mach-at91/pm.c
include/soc/at91/sama7-ddr.h