mirror of
https://github.com/zephyrproject-rtos/zephyr
synced 2025-09-02 17:23:11 +00:00
Namespaced the generated headers with `zephyr` to prevent potential conflict with other headers. Introduce a temporary Kconfig `LEGACY_GENERATED_INCLUDE_PATH` that is enabled by default. This allows the developers to continue the use of the old include paths for the time being until it is deprecated and eventually removed. The Kconfig will generate a build-time warning message, similar to the `CONFIG_TIMER_RANDOM_GENERATOR`. Updated the includes path of in-tree sources accordingly. Most of the changes here are scripted, check the PR for more info. Signed-off-by: Yong Cong Sin <ycsin@meta.com>
94 lines
2.8 KiB
C
94 lines
2.8 KiB
C
/*
|
|
* Copyright (c) 2017 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
#include <zephyr/drivers/i2c.h>
|
|
#include <string.h>
|
|
#include <zephyr/internal/syscall_handler.h>
|
|
|
|
static inline int z_vrfy_i2c_configure(const struct device *dev,
|
|
uint32_t dev_config)
|
|
{
|
|
K_OOPS(K_SYSCALL_DRIVER_I2C(dev, configure));
|
|
return z_impl_i2c_configure((const struct device *)dev, dev_config);
|
|
}
|
|
#include <zephyr/syscalls/i2c_configure_mrsh.c>
|
|
|
|
static inline int z_vrfy_i2c_get_config(const struct device *dev,
|
|
uint32_t *dev_config)
|
|
{
|
|
K_OOPS(K_SYSCALL_DRIVER_I2C(dev, get_config));
|
|
K_OOPS(K_SYSCALL_MEMORY_WRITE(dev_config, sizeof(uint32_t)));
|
|
|
|
return z_impl_i2c_get_config(dev, dev_config);
|
|
}
|
|
#include <zephyr/syscalls/i2c_get_config_mrsh.c>
|
|
|
|
static uint32_t copy_msgs_and_transfer(const struct device *dev,
|
|
const struct i2c_msg *msgs,
|
|
uint8_t num_msgs,
|
|
uint16_t addr)
|
|
{
|
|
struct i2c_msg copy[num_msgs];
|
|
uint8_t i;
|
|
|
|
/* Use a local copy to avoid switcheroo attacks. */
|
|
memcpy(copy, msgs, num_msgs * sizeof(*msgs));
|
|
|
|
/* Validate the buffers in each message struct. Read options require
|
|
* that the target buffer be writable
|
|
*/
|
|
for (i = 0U; i < num_msgs; i++) {
|
|
K_OOPS(K_SYSCALL_MEMORY(copy[i].buf, copy[i].len,
|
|
copy[i].flags & I2C_MSG_READ));
|
|
}
|
|
|
|
return z_impl_i2c_transfer(dev, copy, num_msgs, addr);
|
|
}
|
|
|
|
static inline int z_vrfy_i2c_transfer(const struct device *dev,
|
|
struct i2c_msg *msgs, uint8_t num_msgs,
|
|
uint16_t addr)
|
|
{
|
|
K_OOPS(K_SYSCALL_OBJ(dev, K_OBJ_DRIVER_I2C));
|
|
|
|
/* copy_msgs_and_transfer() will allocate a copy on the stack using
|
|
* VLA, so ensure this won't blow the stack. Most functions defined
|
|
* in i2c.h use only a handful of messages, so up to 32 messages
|
|
* should be more than sufficient.
|
|
*/
|
|
K_OOPS(K_SYSCALL_VERIFY(num_msgs >= 1 && num_msgs < 32));
|
|
|
|
/* We need to be able to read the overall array of messages */
|
|
K_OOPS(K_SYSCALL_MEMORY_ARRAY_READ(msgs, num_msgs,
|
|
sizeof(struct i2c_msg)));
|
|
|
|
return copy_msgs_and_transfer((const struct device *)dev,
|
|
(struct i2c_msg *)msgs,
|
|
(uint8_t)num_msgs, (uint16_t)addr);
|
|
}
|
|
#include <zephyr/syscalls/i2c_transfer_mrsh.c>
|
|
|
|
static inline int z_vrfy_i2c_target_driver_register(const struct device *dev)
|
|
{
|
|
K_OOPS(K_SYSCALL_OBJ(dev, K_OBJ_DRIVER_I2C));
|
|
return z_impl_i2c_target_driver_register(dev);
|
|
}
|
|
#include <zephyr/syscalls/i2c_target_driver_register_mrsh.c>
|
|
|
|
static inline int z_vrfy_i2c_target_driver_unregister(const struct device *dev)
|
|
{
|
|
K_OOPS(K_SYSCALL_OBJ(dev, K_OBJ_DRIVER_I2C));
|
|
return z_impl_i2c_target_driver_unregister(dev);
|
|
}
|
|
#include <zephyr/syscalls/i2c_target_driver_unregister_mrsh.c>
|
|
|
|
static inline int z_vrfy_i2c_recover_bus(const struct device *dev)
|
|
{
|
|
K_OOPS(K_SYSCALL_OBJ(dev, K_OBJ_DRIVER_I2C));
|
|
return z_impl_i2c_recover_bus(dev);
|
|
}
|
|
#include <zephyr/syscalls/i2c_recover_bus_mrsh.c>
|