blob: 8e63e377cb7180830bad3aae54c9972083d54842 [file] [log] [blame]
/*
* Copyright 2024 Ian Morris
*
* SPDX-License-Identifier: Apache-2.0
*/
#include <zephyr/kernel.h>
#include <zephyr/device.h>
#include <zephyr/devicetree.h>
#include <zephyr/drivers/gpio.h>
#include <zephyr/drivers/uart.h>
#define LOG_LEVEL CONFIG_BT_HCI_DRIVER_LOG_LEVEL
#include <zephyr/logging/log.h>
LOG_MODULE_REGISTER(bt_hci_da1453x);
#define DT_DRV_COMPAT renesas_bt_hci_da1453x
int bt_hci_transport_setup(const struct device *h4)
{
int err = 0;
#if DT_INST_NODE_HAS_PROP(0, reset_gpios)
char c;
struct gpio_dt_spec bt_reset = GPIO_DT_SPEC_GET(DT_DRV_INST(0), reset_gpios);
if (!gpio_is_ready_dt(&bt_reset)) {
LOG_ERR("Error: failed to configure bt_reset %s pin %d", bt_reset.port->name,
bt_reset.pin);
return -EIO;
}
/* Set bt_reset as output and activate DA1453x reset */
err = gpio_pin_configure_dt(&bt_reset, GPIO_OUTPUT_ACTIVE);
if (err) {
LOG_ERR("Error %d: failed to configure bt_reset %s pin %d", err,
bt_reset.port->name, bt_reset.pin);
return err;
}
k_sleep(K_MSEC(DT_INST_PROP_OR(0, reset_assert_duration_ms, 0)));
/* Release the DA1453x from reset */
err = gpio_pin_configure_dt(&bt_reset, GPIO_OUTPUT_INACTIVE);
if (err) {
return err;
}
/* Wait for the DA1453x to boot */
k_sleep(K_MSEC(DT_INST_PROP(0, boot_duration_ms)));
/* Drain bytes */
while (h4 && uart_fifo_read(h4, &c, 1)) {
continue;
}
#endif /* DT_INST_NODE_HAS_PROP(0, reset_gpios) */
return err;
}