|  | /* | 
|  | * Copyright (c) 2017 Intel Corporation | 
|  | * Copyright (c) 2020-2021 Vestas Wind Systems A/S | 
|  | * | 
|  | * SPDX-License-Identifier: Apache-2.0 | 
|  | */ | 
|  |  | 
|  | #include <zephyr/internal/syscall_handler.h> | 
|  | #include <zephyr/drivers/pwm.h> | 
|  |  | 
|  | static inline int z_vrfy_pwm_set_cycles(const struct device *dev, | 
|  | uint32_t channel, uint32_t period, | 
|  | uint32_t pulse, pwm_flags_t flags) | 
|  | { | 
|  | K_OOPS(K_SYSCALL_DRIVER_PWM(dev, set_cycles)); | 
|  | return z_impl_pwm_set_cycles((const struct device *)dev, channel, | 
|  | period, pulse, flags); | 
|  | } | 
|  | #include <syscalls/pwm_set_cycles_mrsh.c> | 
|  |  | 
|  | static inline int z_vrfy_pwm_get_cycles_per_sec(const struct device *dev, | 
|  | uint32_t channel, | 
|  | uint64_t *cycles) | 
|  | { | 
|  | K_OOPS(K_SYSCALL_DRIVER_PWM(dev, get_cycles_per_sec)); | 
|  | K_OOPS(K_SYSCALL_MEMORY_WRITE(cycles, sizeof(uint64_t))); | 
|  | return z_impl_pwm_get_cycles_per_sec((const struct device *)dev, | 
|  | channel, (uint64_t *)cycles); | 
|  | } | 
|  | #include <syscalls/pwm_get_cycles_per_sec_mrsh.c> | 
|  |  | 
|  | #ifdef CONFIG_PWM_CAPTURE | 
|  |  | 
|  | static inline int z_vrfy_pwm_enable_capture(const struct device *dev, | 
|  | uint32_t channel) | 
|  | { | 
|  | K_OOPS(K_SYSCALL_DRIVER_PWM(dev, enable_capture)); | 
|  | return z_impl_pwm_enable_capture((const struct device *)dev, channel); | 
|  | } | 
|  | #include <syscalls/pwm_enable_capture_mrsh.c> | 
|  |  | 
|  | static inline int z_vrfy_pwm_disable_capture(const struct device *dev, | 
|  | uint32_t channel) | 
|  | { | 
|  | K_OOPS(K_SYSCALL_DRIVER_PWM(dev, disable_capture)); | 
|  | return z_impl_pwm_disable_capture((const struct device *)dev, channel); | 
|  | } | 
|  | #include <syscalls/pwm_disable_capture_mrsh.c> | 
|  |  | 
|  | static inline int z_vrfy_pwm_capture_cycles(const struct device *dev, | 
|  | uint32_t channel, pwm_flags_t flags, | 
|  | uint32_t *period_cycles, | 
|  | uint32_t *pulse_cycles, | 
|  | k_timeout_t timeout) | 
|  | { | 
|  | uint32_t period; | 
|  | uint32_t pulse; | 
|  | int err; | 
|  |  | 
|  | K_OOPS(K_SYSCALL_DRIVER_PWM(dev, configure_capture)); | 
|  | K_OOPS(K_SYSCALL_DRIVER_PWM(dev, enable_capture)); | 
|  | K_OOPS(K_SYSCALL_DRIVER_PWM(dev, disable_capture)); | 
|  |  | 
|  | err = z_impl_pwm_capture_cycles((const struct device *)dev, channel, | 
|  | flags, &period, &pulse, timeout); | 
|  | if (period_cycles != NULL) { | 
|  | K_OOPS(k_usermode_to_copy(period_cycles, &period, | 
|  | sizeof(*period_cycles))); | 
|  | } | 
|  |  | 
|  | if (pulse_cycles != NULL) { | 
|  | K_OOPS(k_usermode_to_copy(pulse_cycles, &pulse, | 
|  | sizeof(*pulse_cycles))); | 
|  | } | 
|  |  | 
|  | return err; | 
|  | } | 
|  | #include <syscalls/pwm_capture_cycles_mrsh.c> | 
|  |  | 
|  | #endif /* CONFIG_PWM_CAPTURE */ |