1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef __QCOM_SMD_RPM_H__
3 #define __QCOM_SMD_RPM_H__
4 
5 struct qcom_smd_rpm;
6 
7 #define QCOM_SMD_RPM_ACTIVE_STATE        0
8 #define QCOM_SMD_RPM_SLEEP_STATE         1
9 
10 /*
11  * Constants used for addressing resources in the RPM.
12  */
13 #define QCOM_SMD_RPM_BBYB	0x62796262
14 #define QCOM_SMD_RPM_BOBB	0x62626f62
15 #define QCOM_SMD_RPM_BOOST	0x61747362
16 #define QCOM_SMD_RPM_BUS_CLK	0x316b6c63
17 #define QCOM_SMD_RPM_BUS_MASTER	0x73616d62
18 #define QCOM_SMD_RPM_BUS_SLAVE	0x766c7362
19 #define QCOM_SMD_RPM_CLK_BUF_A	0x616B6C63
20 #define QCOM_SMD_RPM_LDOA	0x616f646c
21 #define QCOM_SMD_RPM_LDOB	0x626F646C
22 #define QCOM_SMD_RPM_RWCX	0x78637772
23 #define QCOM_SMD_RPM_RWMX	0x786d7772
24 #define QCOM_SMD_RPM_RWLC	0x636c7772
25 #define QCOM_SMD_RPM_RWLM	0x6d6c7772
26 #define QCOM_SMD_RPM_MEM_CLK	0x326b6c63
27 #define QCOM_SMD_RPM_MISC_CLK	0x306b6c63
28 #define QCOM_SMD_RPM_NCPA	0x6170636E
29 #define QCOM_SMD_RPM_NCPB	0x6270636E
30 #define QCOM_SMD_RPM_OCMEM_PWR	0x706d636f
31 #define QCOM_SMD_RPM_QPIC_CLK	0x63697071
32 #define QCOM_SMD_RPM_QUP_CLK	0x707571
33 #define QCOM_SMD_RPM_SMPA	0x61706d73
34 #define QCOM_SMD_RPM_SMPB	0x62706d73
35 #define QCOM_SMD_RPM_SPDM	0x63707362
36 #define QCOM_SMD_RPM_VSA	0x00617376
37 #define QCOM_SMD_RPM_MMAXI_CLK	0x69786d6d
38 #define QCOM_SMD_RPM_IPA_CLK	0x617069
39 #define QCOM_SMD_RPM_CE_CLK	0x6563
40 #define QCOM_SMD_RPM_AGGR_CLK	0x72676761
41 #define QCOM_SMD_RPM_HWKM_CLK	0x6d6b7768
42 #define QCOM_SMD_RPM_PKA_CLK	0x616b70
43 #define QCOM_SMD_RPM_MCFG_CLK	0x6766636d
44 
45 int qcom_rpm_smd_write(struct qcom_smd_rpm *rpm,
46 		       int state,
47 		       u32 resource_type, u32 resource_id,
48 		       void *buf, size_t count);
49 
50 #endif
51