Linux Audio

Check our new training course

Embedded Linux Audio

Check our new training course
with Creative Commons CC-BY-SA
lecture materials

Bootlin logo

Elixir Cross Referencer

Loading...
/*
 * Copyright (c) 2022 Bjarki Arge Andreasen
 *
 * SPDX-License-Identifier: Apache-2.0
 */

#include <zephyr/drivers/rtc.h>
#include <zephyr/internal/syscall_handler.h>

static inline int z_vrfy_rtc_set_time(const struct device *dev, const struct rtc_time *timeptr)
{
	K_OOPS(K_SYSCALL_DRIVER_RTC(dev, set_time));
	K_OOPS(K_SYSCALL_MEMORY_READ(timeptr, sizeof(struct rtc_time)));
	return z_impl_rtc_set_time(dev, timeptr);
}
#include <zephyr/syscalls/rtc_set_time_mrsh.c>

static inline int z_vrfy_rtc_get_time(const struct device *dev, struct rtc_time *timeptr)
{
	K_OOPS(K_SYSCALL_DRIVER_RTC(dev, get_time));
	K_OOPS(K_SYSCALL_MEMORY_WRITE(timeptr, sizeof(struct rtc_time)));
	return z_impl_rtc_get_time(dev, timeptr);
}
#include <zephyr/syscalls/rtc_get_time_mrsh.c>

#ifdef CONFIG_RTC_ALARM
static inline int z_vrfy_rtc_alarm_get_supported_fields(const struct device *dev, uint16_t id,
							uint16_t *mask)
{
	K_OOPS(K_SYSCALL_DRIVER_RTC(dev, alarm_get_supported_fields));
	K_OOPS(K_SYSCALL_MEMORY_WRITE(mask, sizeof(uint16_t)));
	return z_impl_rtc_alarm_get_supported_fields(dev, id, mask);
}
#include <zephyr/syscalls/rtc_alarm_get_supported_fields_mrsh.c>

static inline int z_vrfy_rtc_alarm_set_time(const struct device *dev, uint16_t id, uint16_t mask,
					    const struct rtc_time *timeptr)
{
	K_OOPS(K_SYSCALL_DRIVER_RTC(dev, alarm_set_time));
	K_OOPS(K_SYSCALL_MEMORY_READ(timeptr, sizeof(struct rtc_time)));
	return z_impl_rtc_alarm_set_time(dev, id, mask, timeptr);
}
#include <zephyr/syscalls/rtc_alarm_set_time_mrsh.c>

static inline int z_vrfy_rtc_alarm_get_time(const struct device *dev, uint16_t id, uint16_t *mask,
					    struct rtc_time *timeptr)
{
	K_OOPS(K_SYSCALL_DRIVER_RTC(dev, alarm_get_time));
	K_OOPS(K_SYSCALL_MEMORY_WRITE(mask, sizeof(uint16_t)));
	K_OOPS(K_SYSCALL_MEMORY_WRITE(timeptr, sizeof(struct rtc_time)));
	return z_impl_rtc_alarm_get_time(dev, id, mask, timeptr);
}
#include <zephyr/syscalls/rtc_alarm_get_time_mrsh.c>

static inline int z_vrfy_rtc_alarm_is_pending(const struct device *dev, uint16_t id)
{
	K_OOPS(K_SYSCALL_DRIVER_RTC(dev, alarm_is_pending));
	return z_impl_rtc_alarm_is_pending(dev, id);
}
#include <zephyr/syscalls/rtc_alarm_is_pending_mrsh.c>
#endif /* CONFIG_RTC_ALARM */

#ifdef CONFIG_RTC_CALIBRATION
static inline int z_vrfy_rtc_set_calibration(const struct device *dev, int32_t calibration)
{
	K_OOPS(K_SYSCALL_DRIVER_RTC(dev, set_calibration));
	return z_impl_rtc_set_calibration(dev, calibration);
}

#include <zephyr/syscalls/rtc_set_calibration_mrsh.c>

static inline int z_vrfy_rtc_get_calibration(const struct device *dev, int32_t *calibration)
{
	K_OOPS(K_SYSCALL_DRIVER_RTC(dev, get_calibration));
	K_OOPS(K_SYSCALL_MEMORY_WRITE(calibration, sizeof(int32_t)));
	return z_impl_rtc_get_calibration(dev, calibration);
}
#include <zephyr/syscalls/rtc_get_calibration_mrsh.c>
#endif /* CONFIG_RTC_CALIBRATION */