2019-05-28 10:10:04 -07:00
// SPDX-License-Identifier: GPL-2.0-only
2013-06-04 07:17:39 +00:00
/*
* Copyright ( C ) 2012 - 2013 Xilinx
*
* CPU idle support for Xilinx Zynq
*
* based on arch / arm / mach - at91 / cpuidle . c
*
* The cpu idle uses wait - for - interrupt and RAM self refresh in order
* to implement two idle states -
* # 1 wait - for - interrupt
* # 2 wait - for - interrupt and RAM self refresh
*
* Maintainer : Michal Simek < michal . simek @ xilinx . com >
*/
# include <linux/init.h>
# include <linux/cpuidle.h>
2013-09-21 18:41:02 +02:00
# include <linux/platform_device.h>
2013-06-04 07:17:39 +00:00
# include <asm/cpuidle.h>
# define ZYNQ_MAX_STATES 2
/* Actual code that puts the SoC in different idle states */
static int zynq_enter_idle ( struct cpuidle_device * dev ,
struct cpuidle_driver * drv , int index )
{
/* Add code for DDR self refresh start */
cpu_do_idle ( ) ;
return index ;
}
static struct cpuidle_driver zynq_idle_driver = {
. name = " zynq_idle " ,
. owner = THIS_MODULE ,
. states = {
ARM_CPUIDLE_WFI_STATE ,
{
. enter = zynq_enter_idle ,
. exit_latency = 10 ,
. target_residency = 10000 ,
. name = " RAM_SR " ,
. desc = " WFI and RAM Self Refresh " ,
} ,
} ,
. safe_state_index = 0 ,
. state_count = ZYNQ_MAX_STATES ,
} ;
/* Initialize CPU idle by registering the idle states */
2013-09-21 18:41:02 +02:00
static int zynq_cpuidle_probe ( struct platform_device * pdev )
2013-06-04 07:17:39 +00:00
{
pr_info ( " Xilinx Zynq CpuIdle Driver started \n " ) ;
return cpuidle_register ( & zynq_idle_driver , NULL ) ;
}
2013-09-21 18:41:02 +02:00
static struct platform_driver zynq_cpuidle_driver = {
. driver = {
. name = " cpuidle-zynq " ,
} ,
. probe = zynq_cpuidle_probe ,
} ;
2015-05-01 20:10:57 -04:00
builtin_platform_driver ( zynq_cpuidle_driver ) ;