zephyr/drivers/gpio/gpio_handlers.c
Tomasz Bursztyka 04d9d57a63 api/gpio: Controller may not support GPIO_INT at all
It's not an error if a driver does not implement callback related
function. Let's return -ENOTSUP relevantly.

Signed-off-by: Tomasz Bursztyka <tomasz.bursztyka@linux.intel.com>
2019-01-25 11:24:29 -05:00

46 lines
1.1 KiB
C

/*
* Copyright (c) 2017 Intel Corporation
*
* SPDX-License-Identifier: Apache-2.0
*/
#include <gpio.h>
#include <syscall_handler.h>
Z_SYSCALL_HANDLER(gpio_config, port, access_op, pin, flags)
{
Z_OOPS(Z_SYSCALL_DRIVER_GPIO(port, config));
return _impl_gpio_config((struct device *)port, access_op, pin, flags);
}
Z_SYSCALL_HANDLER(gpio_write, port, access_op, pin, value)
{
Z_OOPS(Z_SYSCALL_DRIVER_GPIO(port, write));
return _impl_gpio_write((struct device *)port, access_op, pin, value);
}
Z_SYSCALL_HANDLER(gpio_read, port, access_op, pin, value)
{
Z_OOPS(Z_SYSCALL_DRIVER_GPIO(port, read));
Z_OOPS(Z_SYSCALL_MEMORY_WRITE(value, sizeof(u32_t)));
return _impl_gpio_read((struct device *)port, access_op, pin,
(u32_t *)value);
}
Z_SYSCALL_HANDLER(gpio_enable_callback, port, access_op, pin)
{
return _impl_gpio_enable_callback((struct device *)port, access_op,
pin);
}
Z_SYSCALL_HANDLER(gpio_disable_callback, port, access_op, pin)
{
return _impl_gpio_disable_callback((struct device *)port, access_op,
pin);
}
Z_SYSCALL_HANDLER(gpio_get_pending_int, port)
{
return _impl_gpio_get_pending_int((struct device *)port);
}