Zephyr API Documentation 4.4.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
psi5.h
Go to the documentation of this file.
1/*
2 * Copyright 2025 NXP
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
11
12#ifndef ZEPHYR_INCLUDE_DRIVERS_PSI5_H_
13#define ZEPHYR_INCLUDE_DRIVERS_PSI5_H_
14
15#include <zephyr/kernel.h>
16#include <zephyr/device.h>
17
18#ifdef __cplusplus
19extern "C" {
20#endif
21
30
42
73
83typedef void (*psi5_tx_callback_t)(const struct device *dev, uint8_t channel, int status,
84 void *user_data);
85
94typedef void (*psi5_rx_frame_callback_t)(const struct device *dev, uint8_t channel,
95 uint32_t num_frame, void *user_data);
96
98
103typedef int (*psi5_start_sync_t)(const struct device *dev, uint8_t channel);
104
109typedef int (*psi5_stop_sync_t)(const struct device *dev, uint8_t channel);
110
115typedef int (*psi5_send_t)(const struct device *dev, uint8_t channel, const uint64_t data,
116 k_timeout_t timeout, psi5_tx_callback_t callback, void *user_data);
117
121struct psi5_rx_callback_config {
125 struct psi5_frame *frame;
127 uint32_t max_num_frame;
129 void *user_data;
130};
131
135struct psi5_rx_callback_configs {
137 struct psi5_rx_callback_config *serial_frame;
139 struct psi5_rx_callback_config *data_frame;
140};
141
146typedef int (*psi5_register_callback_t)(const struct device *dev, uint8_t channel,
147 struct psi5_rx_callback_configs callback_configs);
148
149__subsystem struct psi5_driver_api {
150 psi5_start_sync_t start_sync;
151 psi5_stop_sync_t stop_sync;
152 psi5_send_t send;
153 psi5_register_callback_t register_callback;
154};
155
157
168__syscall int psi5_start_sync(const struct device *dev, uint8_t channel);
169
170static inline int z_impl_psi5_start_sync(const struct device *dev, uint8_t channel)
171{
172 const struct psi5_driver_api *api = DEVICE_API_GET(psi5, dev);
173
174 if (api->start_sync) {
175 return api->start_sync(dev, channel);
176 }
177
178 return -ENOSYS;
179}
180
191__syscall int psi5_stop_sync(const struct device *dev, uint8_t channel);
192
193static inline int z_impl_psi5_stop_sync(const struct device *dev, uint8_t channel)
194{
195 const struct psi5_driver_api *api = DEVICE_API_GET(psi5, dev);
196
197 if (api->stop_sync) {
198 return api->stop_sync(dev, channel);
199 }
200
201 return -ENOSYS;
202}
203
226__syscall int psi5_send(const struct device *dev, uint8_t channel, const uint64_t data,
227 k_timeout_t timeout, psi5_tx_callback_t callback, void *user_data);
228
229static inline int z_impl_psi5_send(const struct device *dev, uint8_t channel, const uint64_t data,
230 k_timeout_t timeout, psi5_tx_callback_t callback,
231 void *user_data)
232{
233 const struct psi5_driver_api *api = DEVICE_API_GET(psi5, dev);
234
235 if (api->send) {
236 return api->send(dev, channel, data, timeout, callback, user_data);
237 }
238
239 return -ENOSYS;
240}
241
254__syscall int psi5_register_callback(const struct device *dev, uint8_t channel,
255 struct psi5_rx_callback_configs callback_configs);
256
257static inline int z_impl_psi5_register_callback(const struct device *dev, uint8_t channel,
258 struct psi5_rx_callback_configs callback_configs)
259{
260 const struct psi5_driver_api *api = DEVICE_API_GET(psi5, dev);
261
262 if (api->register_callback) {
263 return api->register_callback(dev, channel, callback_configs);
264 }
265
266 return -ENOSYS;
267}
268
269#ifdef __cplusplus
270}
271#endif
272
276
277#include <zephyr/syscalls/psi5.h>
278
279#endif /* ZEPHYR_INCLUDE_DRIVERS_PSI5_H_ */
#define DEVICE_API_GET(_class, _dev)
Expands to the pointer of a device's API for a given class.
Definition device.h:1425
int psi5_register_callback(const struct device *dev, uint8_t channel, struct psi5_rx_callback_configs callback_configs)
Add a callback function to handle messages received for a specific channel.
int psi5_send(const struct device *dev, uint8_t channel, const uint64_t data, k_timeout_t timeout, psi5_tx_callback_t callback, void *user_data)
Transmitting PSI5 data on a specific channel.
psi5_frame_type
PSI5 frame type.
Definition psi5.h:34
void(* psi5_rx_frame_callback_t)(const struct device *dev, uint8_t channel, uint32_t num_frame, void *user_data)
Defines the application callback handler function signature for receiving frame.
Definition psi5.h:94
void(* psi5_tx_callback_t)(const struct device *dev, uint8_t channel, int status, void *user_data)
Defines the application callback handler function signature for sending.
Definition psi5.h:83
int psi5_start_sync(const struct device *dev, uint8_t channel)
Start the sync pulse generator on a specific channel.
int psi5_stop_sync(const struct device *dev, uint8_t channel)
Stop the sync pulse generator on a specific channel.
@ PSI5_SERIAL_FRAME_4_BIT_ID
Serial message frame with 4-bit message ID.
Definition psi5.h:36
@ PSI5_DATA_FRAME
Data frame.
Definition psi5.h:40
@ PSI5_SERIAL_FRAME_8_BIT_ID
Serial message frame with 8-bit message ID.
Definition psi5.h:38
#define ENOSYS
Function not implemented.
Definition errno.h:82
Public kernel APIs.
ssize_t send(int sock, const void *buf, size_t len, int flags)
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINT64_TYPE__ uint64_t
Definition stdint.h:91
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
Runtime device structure (in ROM) per driver instance.
Definition device.h:513
void * data
Address of the device instance private data.
Definition device.h:523
Kernel timeout type.
Definition clock.h:65
PSI5 frame structure.
Definition psi5.h:46
struct psi5_frame::@147241062307066365063355040330314077045061376046::@244231317137073265156064012154356353030045277135 serial
Serial message.
uint32_t data
Message data.
Definition psi5.h:53
uint32_t timestamp
Timestamp of when the frame was captured.
Definition psi5.h:67
enum psi5_frame_type type
Type of PSI5 frame.
Definition psi5.h:48
uint8_t crc
CRC checksum for message integrity validation.
Definition psi5.h:69
uint8_t id
Serial message ID.
Definition psi5.h:60
uint8_t slot_number
Slot Number.
Definition psi5.h:71