|
@@ -70,11 +70,32 @@ static struct cpuidle_driver armadaxp_idle_driver = {
|
|
|
.state_count = 3,
|
|
|
};
|
|
|
|
|
|
+static struct cpuidle_driver armada370_idle_driver = {
|
|
|
+ .name = "armada_370_idle",
|
|
|
+ .states[0] = ARM_CPUIDLE_WFI_STATE,
|
|
|
+ .states[1] = {
|
|
|
+ .enter = mvebu_v7_enter_idle,
|
|
|
+ .exit_latency = 100,
|
|
|
+ .power_usage = 5,
|
|
|
+ .target_residency = 1000,
|
|
|
+ .flags = (CPUIDLE_FLAG_TIME_VALID |
|
|
|
+ MVEBU_V7_FLAG_DEEP_IDLE),
|
|
|
+ .name = "Deep Idle",
|
|
|
+ .desc = "CPU and L2 Fabric power down",
|
|
|
+ },
|
|
|
+ .state_count = 2,
|
|
|
+};
|
|
|
+
|
|
|
static int mvebu_v7_cpuidle_probe(struct platform_device *pdev)
|
|
|
{
|
|
|
-
|
|
|
mvebu_v7_cpu_suspend = pdev->dev.platform_data;
|
|
|
- return cpuidle_register(&armadaxp_idle_driver, NULL);
|
|
|
+
|
|
|
+ if (!strcmp(pdev->dev.driver->name, "cpuidle-armada-xp"))
|
|
|
+ return cpuidle_register(&armadaxp_idle_driver, NULL);
|
|
|
+ else if (!strcmp(pdev->dev.driver->name, "cpuidle-armada-370"))
|
|
|
+ return cpuidle_register(&armada370_idle_driver, NULL);
|
|
|
+ else
|
|
|
+ return -EINVAL;
|
|
|
}
|
|
|
|
|
|
static struct platform_driver armadaxp_cpuidle_plat_driver = {
|
|
@@ -87,6 +108,16 @@ static struct platform_driver armadaxp_cpuidle_plat_driver = {
|
|
|
|
|
|
module_platform_driver(armadaxp_cpuidle_plat_driver);
|
|
|
|
|
|
+static struct platform_driver armada370_cpuidle_plat_driver = {
|
|
|
+ .driver = {
|
|
|
+ .name = "cpuidle-armada-370",
|
|
|
+ .owner = THIS_MODULE,
|
|
|
+ },
|
|
|
+ .probe = mvebu_v7_cpuidle_probe,
|
|
|
+};
|
|
|
+
|
|
|
+module_platform_driver(armada370_cpuidle_plat_driver);
|
|
|
+
|
|
|
MODULE_AUTHOR("Gregory CLEMENT <gregory.clement@free-electrons.com>");
|
|
|
MODULE_DESCRIPTION("Marvell EBU v7 cpuidle driver");
|
|
|
MODULE_LICENSE("GPL");
|