2022-09-07 14:30:23 +02:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2022 Intel Corporation
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
|
|
|
|
2022-10-05 14:40:39 +02:00
|
|
|
#include <zephyr/sys/slist.h>
|
2023-09-27 00:46:01 +02:00
|
|
|
#include <zephyr/internal/syscall_handler.h>
|
2022-10-05 14:40:39 +02:00
|
|
|
#include <zephyr/drivers/smbus.h>
|
2022-09-07 14:30:23 +02:00
|
|
|
|
|
|
|
static inline int z_vrfy_smbus_configure(const struct device *dev,
|
|
|
|
uint32_t dev_config)
|
|
|
|
{
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_DRIVER_SMBUS(dev, configure));
|
2022-09-07 14:30:23 +02:00
|
|
|
|
|
|
|
return z_impl_smbus_configure(dev, dev_config);
|
|
|
|
}
|
|
|
|
#include <syscalls/smbus_configure_mrsh.c>
|
|
|
|
|
|
|
|
static inline int z_vrfy_smbus_get_config(const struct device *dev,
|
|
|
|
uint32_t *dev_config)
|
|
|
|
{
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_DRIVER_SMBUS(dev, get_config));
|
|
|
|
K_OOPS(K_SYSCALL_MEMORY_WRITE(dev_config, sizeof(uint32_t)));
|
2022-09-07 14:30:23 +02:00
|
|
|
|
|
|
|
return z_impl_smbus_get_config(dev, dev_config);
|
|
|
|
}
|
|
|
|
#include <syscalls/smbus_get_config_mrsh.c>
|
|
|
|
|
|
|
|
static inline int z_vrfy_smbus_quick(const struct device *dev, uint16_t addr,
|
|
|
|
enum smbus_direction rw)
|
|
|
|
{
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_OBJ(dev, K_OBJ_DRIVER_SMBUS));
|
2022-09-07 14:30:23 +02:00
|
|
|
|
|
|
|
return z_impl_smbus_quick(dev, addr, rw);
|
|
|
|
}
|
|
|
|
#include <syscalls/smbus_quick_mrsh.c>
|
|
|
|
|
|
|
|
static inline int z_vrfy_smbus_byte_write(const struct device *dev,
|
|
|
|
uint16_t addr, uint8_t byte)
|
|
|
|
{
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_OBJ(dev, K_OBJ_DRIVER_SMBUS));
|
2022-09-07 14:30:23 +02:00
|
|
|
|
|
|
|
return z_impl_smbus_byte_write(dev, addr, byte);
|
|
|
|
}
|
|
|
|
#include <syscalls/smbus_byte_write_mrsh.c>
|
|
|
|
|
|
|
|
static inline int z_vrfy_smbus_byte_read(const struct device *dev,
|
|
|
|
uint16_t addr, uint8_t *byte)
|
|
|
|
{
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_OBJ(dev, K_OBJ_DRIVER_SMBUS));
|
|
|
|
K_OOPS(K_SYSCALL_MEMORY_WRITE(byte, sizeof(uint8_t)));
|
2022-09-07 14:30:23 +02:00
|
|
|
|
|
|
|
return z_impl_smbus_byte_read(dev, addr, byte);
|
|
|
|
}
|
|
|
|
#include <syscalls/smbus_byte_read_mrsh.c>
|
|
|
|
|
|
|
|
static inline int z_vrfy_smbus_byte_data_write(const struct device *dev,
|
|
|
|
uint16_t addr, uint8_t cmd,
|
|
|
|
uint8_t byte)
|
|
|
|
{
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_OBJ(dev, K_OBJ_DRIVER_SMBUS));
|
2022-09-07 14:30:23 +02:00
|
|
|
|
|
|
|
return z_impl_smbus_byte_data_write(dev, addr, cmd, byte);
|
|
|
|
}
|
|
|
|
#include <syscalls/smbus_byte_data_write_mrsh.c>
|
|
|
|
|
|
|
|
static inline int z_vrfy_smbus_byte_data_read(const struct device *dev,
|
|
|
|
uint16_t addr, uint8_t cmd,
|
|
|
|
uint8_t *byte)
|
|
|
|
{
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_OBJ(dev, K_OBJ_DRIVER_SMBUS));
|
|
|
|
K_OOPS(K_SYSCALL_MEMORY_WRITE(byte, sizeof(uint8_t)));
|
2022-09-07 14:30:23 +02:00
|
|
|
|
|
|
|
return z_impl_smbus_byte_data_read(dev, addr, cmd, byte);
|
|
|
|
}
|
|
|
|
#include <syscalls/smbus_byte_data_read_mrsh.c>
|
|
|
|
|
|
|
|
static inline int z_vrfy_smbus_word_data_write(const struct device *dev,
|
|
|
|
uint16_t addr, uint8_t cmd,
|
|
|
|
uint16_t word)
|
|
|
|
{
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_OBJ(dev, K_OBJ_DRIVER_SMBUS));
|
2022-09-07 14:30:23 +02:00
|
|
|
|
|
|
|
return z_impl_smbus_word_data_write(dev, addr, cmd, word);
|
|
|
|
}
|
|
|
|
#include <syscalls/smbus_word_data_write_mrsh.c>
|
|
|
|
|
|
|
|
static inline int z_vrfy_smbus_word_data_read(const struct device *dev,
|
|
|
|
uint16_t addr, uint8_t cmd,
|
|
|
|
uint16_t *word)
|
|
|
|
{
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_OBJ(dev, K_OBJ_DRIVER_SMBUS));
|
|
|
|
K_OOPS(K_SYSCALL_MEMORY_WRITE(word, sizeof(uint16_t)));
|
2022-09-07 14:30:23 +02:00
|
|
|
|
|
|
|
return z_impl_smbus_word_data_read(dev, addr, cmd, word);
|
|
|
|
}
|
|
|
|
#include <syscalls/smbus_word_data_read_mrsh.c>
|
|
|
|
|
|
|
|
static inline int z_vrfy_smbus_pcall(const struct device *dev,
|
|
|
|
uint16_t addr, uint8_t cmd,
|
|
|
|
uint16_t send_word, uint16_t *recv_word)
|
|
|
|
{
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_OBJ(dev, K_OBJ_DRIVER_SMBUS));
|
|
|
|
K_OOPS(K_SYSCALL_MEMORY_WRITE(recv_word, sizeof(uint16_t)));
|
2022-09-07 14:30:23 +02:00
|
|
|
|
|
|
|
return z_impl_smbus_pcall(dev, addr, cmd, send_word, recv_word);
|
|
|
|
}
|
|
|
|
#include <syscalls/smbus_pcall_mrsh.c>
|
|
|
|
|
|
|
|
static inline int z_vrfy_smbus_block_write(const struct device *dev,
|
|
|
|
uint16_t addr, uint8_t cmd,
|
|
|
|
uint8_t count, uint8_t *buf)
|
|
|
|
{
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_OBJ(dev, K_OBJ_DRIVER_SMBUS));
|
|
|
|
K_OOPS(K_SYSCALL_MEMORY_READ(buf, count));
|
2022-09-07 14:30:23 +02:00
|
|
|
|
|
|
|
return z_impl_smbus_block_write(dev, addr, cmd, count, buf);
|
|
|
|
}
|
|
|
|
#include <syscalls/smbus_block_write_mrsh.c>
|
|
|
|
|
|
|
|
static inline int z_vrfy_smbus_block_read(const struct device *dev,
|
|
|
|
uint16_t addr, uint8_t cmd,
|
|
|
|
uint8_t *count, uint8_t *buf)
|
|
|
|
{
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_OBJ(dev, K_OBJ_DRIVER_SMBUS));
|
|
|
|
K_OOPS(K_SYSCALL_MEMORY_WRITE(count, sizeof(uint8_t)));
|
2022-09-07 14:30:23 +02:00
|
|
|
|
|
|
|
return z_impl_smbus_block_read(dev, addr, cmd, count, buf);
|
|
|
|
}
|
|
|
|
#include <syscalls/smbus_block_read_mrsh.c>
|
2022-09-29 15:40:31 +02:00
|
|
|
|
|
|
|
static inline int z_vrfy_smbus_block_pcall(const struct device *dev,
|
|
|
|
uint16_t addr, uint8_t cmd,
|
|
|
|
uint8_t snd_count, uint8_t *snd_buf,
|
|
|
|
uint8_t *rcv_count, uint8_t *rcv_buf)
|
|
|
|
{
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_OBJ(dev, K_OBJ_DRIVER_SMBUS));
|
|
|
|
K_OOPS(K_SYSCALL_MEMORY_READ(snd_buf, snd_count));
|
|
|
|
K_OOPS(K_SYSCALL_MEMORY_WRITE(rcv_count, sizeof(uint8_t)));
|
2022-09-29 15:40:31 +02:00
|
|
|
|
|
|
|
return z_impl_smbus_block_pcall(dev, addr, cmd, snd_count, snd_buf,
|
|
|
|
rcv_count, rcv_buf);
|
|
|
|
}
|
|
|
|
#include <syscalls/smbus_block_pcall_mrsh.c>
|
2022-10-05 14:40:39 +02:00
|
|
|
|
2022-11-04 17:03:32 +01:00
|
|
|
static inline int z_vrfy_smbus_smbalert_remove_cb(const struct device *dev,
|
|
|
|
struct smbus_callback *cb)
|
2022-10-05 14:40:39 +02:00
|
|
|
{
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_OBJ(dev, K_OBJ_DRIVER_SMBUS));
|
2022-10-05 14:40:39 +02:00
|
|
|
|
2022-11-04 17:03:32 +01:00
|
|
|
return z_impl_smbus_smbalert_remove_cb(dev, cb);
|
2022-10-05 14:40:39 +02:00
|
|
|
}
|
2022-11-04 17:03:32 +01:00
|
|
|
#include <syscalls/smbus_smbalert_remove_cb_mrsh.c>
|
|
|
|
|
|
|
|
static inline int z_vrfy_smbus_host_notify_remove_cb(const struct device *dev,
|
|
|
|
struct smbus_callback *cb)
|
|
|
|
{
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_OBJ(dev, K_OBJ_DRIVER_SMBUS));
|
2022-11-04 17:03:32 +01:00
|
|
|
|
|
|
|
return z_impl_smbus_host_notify_remove_cb(dev, cb);
|
|
|
|
}
|
|
|
|
#include <syscalls/smbus_host_notify_remove_cb_mrsh.c>
|