12#ifndef ZEPHYR_INCLUDE_DRIVERS_PSI5_H_
13#define ZEPHYR_INCLUDE_DRIVERS_PSI5_H_
95 uint32_t num_frame,
void *user_data);
103typedef int (*psi5_start_sync_t)(
const struct device *dev,
uint8_t channel);
109typedef int (*psi5_stop_sync_t)(
const struct device *dev,
uint8_t channel);
121struct psi5_rx_callback_config {
135struct psi5_rx_callback_configs {
137 struct psi5_rx_callback_config *serial_frame;
139 struct psi5_rx_callback_config *data_frame;
146typedef int (*psi5_register_callback_t)(
const struct device *dev,
uint8_t channel,
147 struct psi5_rx_callback_configs callback_configs);
149__subsystem
struct psi5_driver_api {
150 psi5_start_sync_t start_sync;
151 psi5_stop_sync_t stop_sync;
153 psi5_register_callback_t register_callback;
170static inline int z_impl_psi5_start_sync(
const struct device *dev,
uint8_t channel)
174 if (api->start_sync) {
175 return api->start_sync(dev, channel);
193static inline int z_impl_psi5_stop_sync(
const struct device *dev,
uint8_t channel)
197 if (api->stop_sync) {
198 return api->stop_sync(dev, channel);
236 return api->send(dev, channel, data, timeout, callback, user_data);
255 struct psi5_rx_callback_configs callback_configs);
257static inline int z_impl_psi5_register_callback(
const struct device *dev,
uint8_t channel,
258 struct psi5_rx_callback_configs callback_configs)
262 if (api->register_callback) {
263 return api->register_callback(dev, channel, callback_configs);
277#include <zephyr/syscalls/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
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