-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
There is a RCPM (Run Control/Power Management) in Freescale QorIQ series processors. The device performs tasks associated with device run control and power management. The driver implements some features: mask/unmask irq, enter/exit low power states, freeze time base, etc. Signed-off-by: Chenhui Zhao <chenhui.zhao@freescale.com> Signed-off-by: Tang Yuantian <Yuantian.Tang@freescale.com> [scottwood: remove __KERNEL__ ifdef] Signed-off-by: Scott Wood <oss@buserror.net>
- Loading branch information
chenhui zhao
authored and
Scott Wood
committed
Mar 5, 2016
1 parent
e7affb1
commit d17799f
Showing
9 changed files
with
571 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
/* | ||
* Support Power Management | ||
* | ||
* Copyright 2014-2015 Freescale Semiconductor Inc. | ||
* | ||
* This program is free software; you can redistribute it and/or modify it | ||
* under the terms of the GNU General Public License as published by the | ||
* Free Software Foundation; either version 2 of the License, or (at your | ||
* option) any later version. | ||
*/ | ||
#ifndef __PPC_FSL_PM_H | ||
#define __PPC_FSL_PM_H | ||
|
||
#define E500_PM_PH10 1 | ||
#define E500_PM_PH15 2 | ||
#define E500_PM_PH20 3 | ||
#define E500_PM_PH30 4 | ||
#define E500_PM_DOZE E500_PM_PH10 | ||
#define E500_PM_NAP E500_PM_PH15 | ||
|
||
#define PLAT_PM_SLEEP 20 | ||
#define PLAT_PM_LPM20 30 | ||
|
||
#define FSL_PM_SLEEP (1 << 0) | ||
#define FSL_PM_DEEP_SLEEP (1 << 1) | ||
|
||
struct fsl_pm_ops { | ||
/* mask pending interrupts to the RCPM from MPIC */ | ||
void (*irq_mask)(int cpu); | ||
|
||
/* unmask pending interrupts to the RCPM from MPIC */ | ||
void (*irq_unmask)(int cpu); | ||
void (*cpu_enter_state)(int cpu, int state); | ||
void (*cpu_exit_state)(int cpu, int state); | ||
void (*cpu_up_prepare)(int cpu); | ||
void (*cpu_die)(int cpu); | ||
int (*plat_enter_sleep)(void); | ||
void (*freeze_time_base)(bool freeze); | ||
|
||
/* keep the power of IP blocks during sleep/deep sleep */ | ||
void (*set_ip_power)(bool enable, u32 mask); | ||
|
||
/* get platform supported power management modes */ | ||
unsigned int (*get_pm_modes)(void); | ||
}; | ||
|
||
extern const struct fsl_pm_ops *qoriq_pm_ops; | ||
|
||
int __init fsl_rcpm_init(void); | ||
|
||
#endif /* __PPC_FSL_PM_H */ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.