1 /*
2  * Copyright (c) 2013-2018, ARM Limited and Contributors. All rights reserved.
3  *
4  * SPDX-License-Identifier: BSD-3-Clause
5  */
6 
7 /*
8  * Contains definitions of commonly used macros and data types needed
9  * for PU Power Management. This file should be common for all PU's.
10  */
11 
12 #ifndef PM_COMMON_H
13 #define PM_COMMON_H
14 
15 #include <stdint.h>
16 #include <plat_pm_common.h>
17 
18 #if IPI_CRC_CHECK
19 #define PAYLOAD_ARG_CNT         8U
20 #define IPI_W0_TO_W6_SIZE       28U
21 #define PAYLOAD_CRC_POS         7U
22 #define CRC_INIT_VALUE          0x4F4EU
23 #define CRC_ORDER               16U
24 #define CRC_POLYNOM             0x8005U
25 #else
26 #define PAYLOAD_ARG_CNT         6U
27 #endif
28 #define PAYLOAD_ARG_SIZE	4U	/* size in bytes */
29 
30 /**
31  * pm_ipi - struct for capturing IPI-channel specific info
32  * @local_ipi_id	Local IPI agent ID
33  * @remote_ipi_id	Remote IPI Agent ID
34  * @buffer_base	base address for payload buffer
35  */
36 struct pm_ipi {
37 	const uint32_t local_ipi_id;
38 	const uint32_t remote_ipi_id;
39 	const uintptr_t buffer_base;
40 };
41 
42 /**
43  * pm_proc - struct for capturing processor related info
44  * @node_id	node-ID of the processor
45  * @pwrdn_mask	cpu-specific mask to be used for power control register
46  * @ipi		pointer to IPI channel structure
47  *		(in APU all processors share one IPI channel)
48  */
49 struct pm_proc {
50 	const uint32_t node_id;
51 	const uint32_t pwrdn_mask;
52 	const struct pm_ipi *ipi;
53 };
54 
55 const struct pm_proc *pm_get_proc(uint32_t cpuid);
56 
57 #endif /* PM_COMMON_H */
58