Skip to content

Commit 60b89f1

Browse files
noglitchalexandrebelloni
authored andcommitted
ARM: at91: pm: cpu_idle: switch DDR to power-down mode
On some DDR controllers, compatible with the sama5d3 one, the sequence to enter/exit/re-enter the self-refresh mode adds more constrains than what is currently written in the at91_idle driver. An actual access to the DDR chip is needed between exit and re-enter of this mode which is somehow difficult to implement. This sequence can completely hang the SoC. It is particularly experienced on parts which embed a L2 cache if the code run between IDLE calls fits in it... Moreover, as the intention is to enter and exit pretty rapidly from IDLE, the power-down mode is a good candidate. So now we use power-down instead of self-refresh. As we can simplify the code for sama5d3 compatible DDR controllers, we instantiate a new sama5d3_ddr_standby() function. Signed-off-by: Nicolas Ferre <nicolas.ferre@microchip.com> Cc: <stable@vger.kernel.org> # v4.1+ Fixes: 017b552 ("ARM: at91: Add new binding for sama5d3-ddramc") Signed-off-by: Alexandre Belloni <alexandre.belloni@free-electrons.com>
1 parent 9e10889 commit 60b89f1

File tree

1 file changed

+17
-1
lines changed
  • arch/arm/mach-at91

1 file changed

+17
-1
lines changed

arch/arm/mach-at91/pm.c

Lines changed: 17 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -289,6 +289,22 @@ static void at91_ddr_standby(void)
289289
at91_ramc_write(1, AT91_DDRSDRC_LPR, saved_lpr1);
290290
}
291291

292+
static void sama5d3_ddr_standby(void)
293+
{
294+
u32 lpr0;
295+
u32 saved_lpr0;
296+
297+
saved_lpr0 = at91_ramc_read(0, AT91_DDRSDRC_LPR);
298+
lpr0 = saved_lpr0 & ~AT91_DDRSDRC_LPCB;
299+
lpr0 |= AT91_DDRSDRC_LPCB_POWER_DOWN;
300+
301+
at91_ramc_write(0, AT91_DDRSDRC_LPR, lpr0);
302+
303+
cpu_do_idle();
304+
305+
at91_ramc_write(0, AT91_DDRSDRC_LPR, saved_lpr0);
306+
}
307+
292308
/* We manage both DDRAM/SDRAM controllers, we need more than one value to
293309
* remember.
294310
*/
@@ -323,7 +339,7 @@ static const struct of_device_id const ramc_ids[] __initconst = {
323339
{ .compatible = "atmel,at91rm9200-sdramc", .data = at91rm9200_standby },
324340
{ .compatible = "atmel,at91sam9260-sdramc", .data = at91sam9_sdram_standby },
325341
{ .compatible = "atmel,at91sam9g45-ddramc", .data = at91_ddr_standby },
326-
{ .compatible = "atmel,sama5d3-ddramc", .data = at91_ddr_standby },
342+
{ .compatible = "atmel,sama5d3-ddramc", .data = sama5d3_ddr_standby },
327343
{ /*sentinel*/ }
328344
};
329345

0 commit comments

Comments
 (0)