1/* SPDX-License-Identifier: GPL-2.0+ */
2/*
3 * Copyright (C) 2016 Freescale Semiconductor, Inc.
4 * Copyright 2017-2018 NXP
5 *
6 * Header file containing the public API for the System Controller (SC)
7 * Power Management (PM) function. This includes functions for power state
8 * control, clock control, reset control, and wake-up event control.
9 *
10 * PM_SVC (SVC) Power Management Service
11 *
12 * Module for the Power Management (PM) service.
13 */
14
15#ifndef _SC_PM_API_H
16#define _SC_PM_API_H
17
18#include <linux/firmware/imx/sci.h>
19
20/*
21 * This type is used to indicate RPC PM function calls.
22 */
23enum imx_sc_pm_func {
24 IMX_SC_PM_FUNC_UNKNOWN = 0,
25 IMX_SC_PM_FUNC_SET_SYS_POWER_MODE = 19,
26 IMX_SC_PM_FUNC_SET_PARTITION_POWER_MODE = 1,
27 IMX_SC_PM_FUNC_GET_SYS_POWER_MODE = 2,
28 IMX_SC_PM_FUNC_SET_RESOURCE_POWER_MODE = 3,
29 IMX_SC_PM_FUNC_GET_RESOURCE_POWER_MODE = 4,
30 IMX_SC_PM_FUNC_REQ_LOW_POWER_MODE = 16,
31 IMX_SC_PM_FUNC_SET_CPU_RESUME_ADDR = 17,
32 IMX_SC_PM_FUNC_REQ_SYS_IF_POWER_MODE = 18,
33 IMX_SC_PM_FUNC_SET_CLOCK_RATE = 5,
34 IMX_SC_PM_FUNC_GET_CLOCK_RATE = 6,
35 IMX_SC_PM_FUNC_CLOCK_ENABLE = 7,
36 IMX_SC_PM_FUNC_SET_CLOCK_PARENT = 14,
37 IMX_SC_PM_FUNC_GET_CLOCK_PARENT = 15,
38 IMX_SC_PM_FUNC_RESET = 13,
39 IMX_SC_PM_FUNC_RESET_REASON = 10,
40 IMX_SC_PM_FUNC_BOOT = 8,
41 IMX_SC_PM_FUNC_REBOOT = 9,
42 IMX_SC_PM_FUNC_REBOOT_PARTITION = 12,
43 IMX_SC_PM_FUNC_CPU_START = 11,
44};
45
46/*
47 * Defines for ALL parameters
48 */
49#define IMX_SC_PM_CLK_ALL UINT8_MAX /* All clocks */
50
51/*
52 * Defines for SC PM Power Mode
53 */
54#define IMX_SC_PM_PW_MODE_OFF 0 /* Power off */
55#define IMX_SC_PM_PW_MODE_STBY 1 /* Power in standby */
56#define IMX_SC_PM_PW_MODE_LP 2 /* Power in low-power */
57#define IMX_SC_PM_PW_MODE_ON 3 /* Power on */
58
59/*
60 * Defines for SC PM CLK
61 */
62#define IMX_SC_PM_CLK_SLV_BUS 0 /* Slave bus clock */
63#define IMX_SC_PM_CLK_MST_BUS 1 /* Master bus clock */
64#define IMX_SC_PM_CLK_PER 2 /* Peripheral clock */
65#define IMX_SC_PM_CLK_PHY 3 /* Phy clock */
66#define IMX_SC_PM_CLK_MISC 4 /* Misc clock */
67#define IMX_SC_PM_CLK_MISC0 0 /* Misc 0 clock */
68#define IMX_SC_PM_CLK_MISC1 1 /* Misc 1 clock */
69#define IMX_SC_PM_CLK_MISC2 2 /* Misc 2 clock */
70#define IMX_SC_PM_CLK_MISC3 3 /* Misc 3 clock */
71#define IMX_SC_PM_CLK_MISC4 4 /* Misc 4 clock */
72#define IMX_SC_PM_CLK_CPU 2 /* CPU clock */
73#define IMX_SC_PM_CLK_PLL 4 /* PLL */
74#define IMX_SC_PM_CLK_BYPASS 4 /* Bypass clock */
75
76/*
77 * Defines for SC PM CLK Parent
78 */
79#define IMX_SC_PM_PARENT_XTAL 0 /* Parent is XTAL. */
80#define IMX_SC_PM_PARENT_PLL0 1 /* Parent is PLL0 */
81#define IMX_SC_PM_PARENT_PLL1 2 /* Parent is PLL1 or PLL0/2 */
82#define IMX_SC_PM_PARENT_PLL2 3 /* Parent in PLL2 or PLL0/4 */
83#define IMX_SC_PM_PARENT_BYPS 4 /* Parent is a bypass clock. */
84
85#endif /* _SC_PM_API_H */
86

source code of linux/include/linux/firmware/imx/svc/pm.h