1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/drivers/atwinc15x0/atwinc15x0_bsp.c

99 lines
2.0 KiB
C
Raw Normal View History

/*
* Copyright (C) 2020 Gunar Schorcht
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
* @ingroup drivers_atwinc15x0
* @{
*
* @file
* @brief RIOT BSP API implementation
*
* @author Gunar Schorcht <gunar@schorcht.net>
*
* @}
*/
#include "atwinc15x0_internal.h"
#include "mutex.h"
#include "periph/spi.h"
#include "xtimer.h"
#define ENABLE_DEBUG (0)
#include "debug.h"
void atwinc15x0_isr(void *arg)
{
(void)arg;
if (atwinc15x0->bsp_isr != NULL && atwinc15x0->bsp_irq_enabled) {
atwinc15x0->bsp_isr();
}
atwinc15x0_irq();
}
sint8 nm_bsp_init(void)
{
assert(atwinc15x0);
assert(atwinc15x0->params.reset_pin != GPIO_UNDEF);
assert(atwinc15x0->params.irq_pin != GPIO_UNDEF);
gpio_init(atwinc15x0->params.reset_pin, GPIO_OUT);
gpio_set(atwinc15x0->params.reset_pin);
gpio_init_int(atwinc15x0->params.irq_pin, GPIO_IN_PU, GPIO_FALLING,
atwinc15x0_isr, NULL);
if (atwinc15x0->params.chip_en_pin != GPIO_UNDEF) {
gpio_init(atwinc15x0->params.chip_en_pin, GPIO_OUT);
gpio_set(atwinc15x0->params.chip_en_pin);
}
if (atwinc15x0->params.wake_pin != GPIO_UNDEF) {
gpio_init(atwinc15x0->params.wake_pin, GPIO_OUT);
gpio_set(atwinc15x0->params.wake_pin);
}
return 0;
}
sint8 nm_bsp_deinit(void)
{
return 0;
}
void nm_bsp_reset(void)
{
assert(atwinc15x0);
gpio_clear(atwinc15x0->params.reset_pin);
nm_bsp_sleep(100);
gpio_set(atwinc15x0->params.reset_pin);
nm_bsp_sleep(100);
}
void nm_bsp_sleep(uint32 u32TimeMsec)
{
xtimer_usleep(u32TimeMsec * US_PER_MS);
}
void nm_bsp_register_isr(tpfNmBspIsr pfIsr)
{
assert(atwinc15x0);
DEBUG("%s %p\n", __func__, (void *)(uintptr_t)pfIsr);
atwinc15x0->bsp_isr = pfIsr;
}
void nm_bsp_interrupt_ctrl(uint8 u8Enable)
{
assert(atwinc15x0);
DEBUG("%s %u\n", __func__, u8Enable);
atwinc15x0->bsp_irq_enabled = u8Enable;
}