2020-03-25 00:18:19 +01:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2020 Intel Corporation
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
|
|
|
|
2022-05-06 10:25:46 +02:00
|
|
|
#include <zephyr/drivers/espi.h>
|
2023-09-27 00:46:01 +02:00
|
|
|
#include <zephyr/internal/syscall_handler.h>
|
2020-03-25 00:18:19 +01:00
|
|
|
|
|
|
|
|
2020-04-30 20:33:38 +02:00
|
|
|
static inline int z_vrfy_espi_config(const struct device *dev,
|
|
|
|
struct espi_cfg *cfg)
|
2020-03-25 00:18:19 +01:00
|
|
|
{
|
|
|
|
struct espi_cfg cfg_copy;
|
|
|
|
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_DRIVER_ESPI(dev, config));
|
|
|
|
K_OOPS(k_usermode_from_copy(&cfg_copy, cfg,
|
2020-03-25 00:18:19 +01:00
|
|
|
sizeof(struct espi_cfg)));
|
|
|
|
|
|
|
|
return z_impl_espi_config(dev, &cfg_copy);
|
|
|
|
}
|
|
|
|
#include <syscalls/espi_config_mrsh.c>
|
|
|
|
|
2020-04-30 20:33:38 +02:00
|
|
|
static inline bool z_vrfy_espi_get_channel_status(const struct device *dev,
|
2020-03-25 00:18:19 +01:00
|
|
|
enum espi_channel ch)
|
|
|
|
{
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_DRIVER_ESPI(dev, get_channel_status));
|
2020-03-25 00:18:19 +01:00
|
|
|
|
|
|
|
return z_impl_espi_get_channel_status(dev, ch);
|
|
|
|
}
|
|
|
|
#include <syscalls/espi_get_channel_status_mrsh.c>
|
|
|
|
|
2020-04-30 20:33:38 +02:00
|
|
|
static inline int z_vrfy_espi_read_lpc_request(const struct device *dev,
|
2020-03-25 00:18:19 +01:00
|
|
|
enum lpc_peripheral_opcode op,
|
2020-05-27 18:26:57 +02:00
|
|
|
uint32_t *data)
|
2020-03-25 00:18:19 +01:00
|
|
|
{
|
|
|
|
int ret;
|
2020-05-27 18:26:57 +02:00
|
|
|
uint32_t data_copy;
|
2020-03-25 00:18:19 +01:00
|
|
|
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_DRIVER_ESPI(dev, read_lpc_request));
|
2020-03-25 00:18:19 +01:00
|
|
|
|
|
|
|
ret = z_impl_espi_read_lpc_request(dev, op, &data_copy);
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(k_usermode_to_copy(data, &data_copy, sizeof(uint8_t)));
|
2020-03-25 00:18:19 +01:00
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
#include <syscalls/espi_read_lpc_request_mrsh.c>
|
|
|
|
|
2020-04-30 20:33:38 +02:00
|
|
|
static inline int z_vrfy_espi_write_lpc_request(const struct device *dev,
|
2020-03-25 00:18:19 +01:00
|
|
|
enum lpc_peripheral_opcode op,
|
2020-05-27 18:26:57 +02:00
|
|
|
uint32_t *data)
|
2020-03-25 00:18:19 +01:00
|
|
|
{
|
2020-05-27 18:26:57 +02:00
|
|
|
uint32_t data_copy;
|
2020-03-25 00:18:19 +01:00
|
|
|
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_DRIVER_ESPI(dev, write_lpc_request));
|
|
|
|
K_OOPS(k_usermode_from_copy(&data_copy, data, sizeof(*data)));
|
2020-03-25 00:18:19 +01:00
|
|
|
|
2020-09-10 11:49:56 +02:00
|
|
|
return z_impl_espi_write_lpc_request(dev, op, &data_copy);
|
2020-03-25 00:18:19 +01:00
|
|
|
}
|
|
|
|
#include <syscalls/espi_write_lpc_request_mrsh.c>
|
|
|
|
|
2020-04-30 20:33:38 +02:00
|
|
|
static inline int z_vrfy_espi_send_vwire(const struct device *dev,
|
2020-03-25 00:18:19 +01:00
|
|
|
enum espi_vwire_signal signal,
|
2020-05-27 18:26:57 +02:00
|
|
|
uint8_t level)
|
2020-03-25 00:18:19 +01:00
|
|
|
{
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_DRIVER_ESPI(dev, send_vwire));
|
2020-03-25 00:18:19 +01:00
|
|
|
|
|
|
|
return z_impl_espi_send_vwire(dev, signal, level);
|
|
|
|
}
|
|
|
|
#include <syscalls/espi_send_vwire_mrsh.c>
|
|
|
|
|
2020-04-30 20:33:38 +02:00
|
|
|
static inline int z_vrfy_espi_receive_vwire(const struct device *dev,
|
2020-03-25 00:18:19 +01:00
|
|
|
enum espi_vwire_signal signal,
|
2020-05-27 18:26:57 +02:00
|
|
|
uint8_t *level)
|
2020-03-25 00:18:19 +01:00
|
|
|
{
|
|
|
|
int ret;
|
2020-05-27 18:26:57 +02:00
|
|
|
uint8_t level_copy;
|
2020-03-25 00:18:19 +01:00
|
|
|
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_DRIVER_ESPI(dev, receive_vwire));
|
2020-03-25 00:18:19 +01:00
|
|
|
|
|
|
|
ret = z_impl_espi_receive_vwire(dev, signal, &level_copy);
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(k_usermode_to_copy(level, &level_copy, sizeof(uint8_t)));
|
2020-03-25 00:18:19 +01:00
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
#include <syscalls/espi_receive_vwire_mrsh.c>
|
2020-03-25 22:42:52 +01:00
|
|
|
|
2020-04-30 20:33:38 +02:00
|
|
|
static inline int z_vrfy_espi_read_request(const struct device *dev,
|
2020-03-25 22:42:52 +01:00
|
|
|
struct espi_request_packet *req)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
struct espi_request_packet req_copy;
|
|
|
|
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_DRIVER_ESPI(dev, read_request));
|
|
|
|
K_OOPS(k_usermode_from_copy(&req_copy, req,
|
2020-03-25 22:42:52 +01:00
|
|
|
sizeof(struct espi_request_packet)));
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_MEMORY_WRITE(req_copy.data, req_copy.len));
|
2020-03-25 22:42:52 +01:00
|
|
|
|
|
|
|
ret = z_impl_espi_read_request(dev, &req_copy);
|
|
|
|
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(k_usermode_to_copy(req, &req_copy,
|
2020-03-25 22:42:52 +01:00
|
|
|
sizeof(struct espi_request_packet)));
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
#include <syscalls/espi_read_request_mrsh.c>
|
|
|
|
|
2020-04-30 20:33:38 +02:00
|
|
|
static inline int z_vrfy_espi_write_request(const struct device *dev,
|
2020-03-25 22:42:52 +01:00
|
|
|
struct espi_request_packet *req)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
struct espi_request_packet req_copy;
|
|
|
|
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_DRIVER_ESPI(dev, write_request));
|
|
|
|
K_OOPS(K_SYSCALL_MEMORY_READ(req->data, req->len));
|
|
|
|
K_OOPS(k_usermode_from_copy(&req_copy, req,
|
2020-03-25 22:42:52 +01:00
|
|
|
sizeof(struct espi_request_packet)));
|
|
|
|
|
|
|
|
ret = z_impl_espi_write_request(dev, &req_copy);
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
#include <syscalls/espi_write_request_mrsh.c>
|
|
|
|
|
2020-04-30 20:33:38 +02:00
|
|
|
static inline int z_vrfy_espi_send_oob(const struct device *dev,
|
2020-03-25 22:42:52 +01:00
|
|
|
struct espi_oob_packet *pckt)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
struct espi_oob_packet pckt_copy;
|
|
|
|
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_DRIVER_ESPI(dev, send_oob));
|
|
|
|
K_OOPS(K_SYSCALL_MEMORY_READ(pckt->buf, pckt->len));
|
|
|
|
K_OOPS(k_usermode_from_copy(&pckt_copy, pckt,
|
2020-03-25 22:42:52 +01:00
|
|
|
sizeof(struct espi_oob_packet)));
|
|
|
|
|
|
|
|
ret = z_impl_espi_send_oob(dev, &pckt_copy);
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
#include <syscalls/espi_send_oob_mrsh.c>
|
|
|
|
|
2020-04-30 20:33:38 +02:00
|
|
|
static inline int z_vrfy_espi_receive_oob(const struct device *dev,
|
2020-03-25 22:42:52 +01:00
|
|
|
struct espi_oob_packet *pckt)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
struct espi_oob_packet pckt_copy;
|
|
|
|
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_DRIVER_ESPI(dev, receive_oob));
|
|
|
|
K_OOPS(k_usermode_from_copy(&pckt_copy, pckt,
|
2020-03-25 22:42:52 +01:00
|
|
|
sizeof(struct espi_oob_packet)));
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_MEMORY_WRITE(pckt->buf, pckt->len));
|
2020-03-25 22:42:52 +01:00
|
|
|
|
|
|
|
ret = z_impl_espi_receive_oob(dev, &pckt_copy);
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(k_usermode_to_copy(pckt, &pckt_copy,
|
2020-03-25 22:42:52 +01:00
|
|
|
sizeof(struct espi_oob_packet)));
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
#include <syscalls/espi_receive_oob_mrsh.c>
|
|
|
|
|
2020-04-30 20:33:38 +02:00
|
|
|
static inline int z_vrfy_espi_read_flash(const struct device *dev,
|
2020-03-25 22:42:52 +01:00
|
|
|
struct espi_flash_packet *pckt)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
struct espi_flash_packet pckt_copy;
|
|
|
|
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_DRIVER_ESPI(dev, flash_read));
|
|
|
|
K_OOPS(k_usermode_from_copy(&pckt_copy, pckt,
|
2020-03-25 22:42:52 +01:00
|
|
|
sizeof(struct espi_flash_packet)));
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_MEMORY_WRITE(pckt->buf, pckt->len));
|
2020-03-25 22:42:52 +01:00
|
|
|
|
|
|
|
ret = z_impl_espi_read_flash(dev, pckt);
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(k_usermode_to_copy(pckt, &pckt_copy,
|
2020-03-25 22:42:52 +01:00
|
|
|
sizeof(struct espi_flash_packet)));
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
#include <syscalls/espi_read_flash_mrsh.c>
|
|
|
|
|
2020-04-30 20:33:38 +02:00
|
|
|
static inline int z_vrfy_espi_write_flash(const struct device *dev,
|
2020-03-25 22:42:52 +01:00
|
|
|
struct espi_flash_packet *pckt)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
struct espi_flash_packet pckt_copy;
|
|
|
|
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_DRIVER_ESPI(dev, flash_write));
|
|
|
|
K_OOPS(k_usermode_from_copy(&pckt_copy, pckt,
|
2020-03-25 22:42:52 +01:00
|
|
|
sizeof(struct espi_flash_packet)));
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_MEMORY_READ(pckt->buf, pckt->len));
|
2020-03-25 22:42:52 +01:00
|
|
|
|
|
|
|
ret = z_impl_espi_write_flash(dev, &pckt_copy);
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
#include <syscalls/espi_write_flash_mrsh.c>
|
|
|
|
|
2020-04-30 20:33:38 +02:00
|
|
|
static inline int z_vrfy_espi_flash_erase(const struct device *dev,
|
2020-03-25 22:42:52 +01:00
|
|
|
struct espi_flash_packet *pckt)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
struct espi_flash_packet pckt_copy;
|
|
|
|
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_DRIVER_ESPI(dev, flash_write));
|
|
|
|
K_OOPS(k_usermode_from_copy(&pckt_copy, pckt,
|
2020-03-25 22:42:52 +01:00
|
|
|
sizeof(struct espi_flash_packet)));
|
2023-09-27 13:20:28 +02:00
|
|
|
K_OOPS(K_SYSCALL_MEMORY_READ(pckt->buf, pckt->len));
|
2020-03-25 22:42:52 +01:00
|
|
|
|
|
|
|
ret = z_impl_espi_flash_erase(dev, &pckt_copy);
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
#include <syscalls/espi_flash_erase_mrsh.c>
|