Zephyr API Documentation
4.0.0
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
util.h
Go to the documentation of this file.
1
/*
2
* Copyright 2024 NXP
3
*
4
* SPDX-License-Identifier: Apache-2.0
5
*/
6
15
#ifndef _INCLUDE_ZEPHYR_DRIVERS_FIRMWARE_SCMI_UTIL_H_
16
#define _INCLUDE_ZEPHYR_DRIVERS_FIRMWARE_SCMI_UTIL_H_
17
29
#define SCMI_PROTOCOL_NAME(proto) CONCAT(scmi_protocol_, proto)
30
31
#ifdef CONFIG_ARM_SCMI_TRANSPORT_HAS_STATIC_CHANNELS
32
33
#ifdef CONFIG_ARM_SCMI_MAILBOX_TRANSPORT
47
#define DT_SCMI_TRANSPORT_PROTO_HAS_CHAN(node_id, idx)\
48
DT_PROP_HAS_IDX(node_id, shmem, idx)
49
#else
/* CONFIG_ARM_SCMI_MAILBOX_TRANSPORT */
50
#error "Transport with static channels needs to define HAS_CHAN macro"
51
#endif
/* CONFIG_ARM_SCMI_MAILBOX_TRANSPORT */
52
53
#define SCMI_TRANSPORT_CHAN_NAME(proto, idx) CONCAT(scmi_channel_, proto, _, idx)
54
66
#define DT_SCMI_TRANSPORT_TX_CHAN_DECLARE(node_id) \
67
COND_CODE_1(DT_SCMI_TRANSPORT_PROTO_HAS_CHAN(node_id, 0), \
68
(extern struct scmi_channel \
69
SCMI_TRANSPORT_CHAN_NAME(DT_REG_ADDR_RAW(node_id), 0);), \
70
(extern struct scmi_channel \
71
SCMI_TRANSPORT_CHAN_NAME(SCMI_PROTOCOL_BASE, 0);)) \
72
85
#define DT_SCMI_TRANSPORT_CHANNELS_DECLARE(node_id) \
86
DT_SCMI_TRANSPORT_TX_CHAN_DECLARE(node_id) \
87
96
#define DT_INST_SCMI_TRANSPORT_CHANNELS_DECLARE(inst) \
97
DT_SCMI_TRANSPORT_CHANNELS_DECLARE(DT_INST(inst, DT_DRV_COMPAT))
98
111
#define DT_SCMI_TRANSPORT_TX_CHAN(node_id) \
112
COND_CODE_1(DT_SCMI_TRANSPORT_PROTO_HAS_CHAN(node_id, 0), \
113
(&SCMI_TRANSPORT_CHAN_NAME(DT_REG_ADDR_RAW(node_id), 0)), \
114
(&SCMI_TRANSPORT_CHAN_NAME(SCMI_PROTOCOL_BASE, 0)))
115
128
#define DT_SCMI_TRANSPORT_CHAN_DEFINE(node_id, idx, proto, pdata) \
129
struct scmi_channel SCMI_TRANSPORT_CHAN_NAME(proto, idx) = \
130
{ \
131
.data = pdata, \
132
}
133
149
#define DT_SCMI_PROTOCOL_DATA_DEFINE(node_id, proto, pdata) \
150
STRUCT_SECTION_ITERABLE(scmi_protocol, SCMI_PROTOCOL_NAME(proto)) = \
151
{ \
152
.id = proto, \
153
.tx = DT_SCMI_TRANSPORT_TX_CHAN(node_id), \
154
.data = pdata, \
155
}
156
157
#else
/* CONFIG_ARM_SCMI_TRANSPORT_HAS_STATIC_CHANNELS */
158
159
#define DT_SCMI_TRANSPORT_CHANNELS_DECLARE(node_id)
160
161
#define DT_SCMI_PROTOCOL_DATA_DEFINE(node_id, proto, pdata) \
162
STRUCT_SECTION_ITERABLE(scmi_protocol, SCMI_PROTOCOL_NAME(proto)) = \
163
{ \
164
.id = proto, \
165
.data = pdata, \
166
}
167
168
#endif
/* CONFIG_ARM_SCMI_TRANSPORT_HAS_STATIC_CHANNELS */
169
182
#define DT_INST_SCMI_TRANSPORT_DEFINE(inst, pm, data, config, level, prio, api) \
183
DEVICE_DT_INST_DEFINE(inst, &scmi_core_transport_init, \
184
pm, data, config, level, prio, api)
185
211
#define DT_SCMI_PROTOCOL_DEFINE(node_id, init_fn, pm, data, config, \
212
level, prio, api) \
213
DT_SCMI_TRANSPORT_CHANNELS_DECLARE(node_id) \
214
DT_SCMI_PROTOCOL_DATA_DEFINE(node_id, DT_REG_ADDR_RAW(node_id), data); \
215
DEVICE_DT_DEFINE(node_id, init_fn, pm, \
216
&SCMI_PROTOCOL_NAME(DT_REG_ADDR_RAW(node_id)), \
217
config, level, prio, api)
218
232
#define DT_INST_SCMI_PROTOCOL_DEFINE(inst, init_fn, pm, data, config, \
233
level, prio, api) \
234
DT_SCMI_PROTOCOL_DEFINE(DT_INST(inst, DT_DRV_COMPAT), init_fn, pm, \
235
data, config, level, prio, api)
236
248
#define DT_SCMI_PROTOCOL_DEFINE_NODEV(node_id, data) \
249
DT_SCMI_TRANSPORT_CHANNELS_DECLARE(node_id) \
250
DT_SCMI_PROTOCOL_DATA_DEFINE(node_id, DT_REG_ADDR_RAW(node_id), data)
251
264
#define SCMI_FIELD_MAKE(x, mask, shift)\
265
(((uint32_t)(x) & (mask)) << (shift))
266
275
#define SCMI_PROTOCOL_BASE 16
276
#define SCMI_PROTOCOL_POWER_DOMAIN 17
277
#define SCMI_PROTOCOL_SYSTEM 18
278
#define SCMI_PROTOCOL_PERF 19
279
#define SCMI_PROTOCOL_CLOCK 20
280
#define SCMI_PROTOCOL_SENSOR 21
281
#define SCMI_PROTOCOL_RESET_DOMAIN 22
282
#define SCMI_PROTOCOL_VOLTAGE_DOMAIN 23
283
#define SCMI_PROTOCOL_PCAP_MONITOR 24
284
#define SCMI_PROTOCOL_PINCTRL 25
285
286
#endif
/* _INCLUDE_ZEPHYR_DRIVERS_FIRMWARE_SCMI_UTIL_H_ */
zephyr
drivers
firmware
scmi
util.h
Generated on Sat Nov 16 2024 04:55:03 for Zephyr API Documentation by
1.12.0