/* * Copyright 2024 Ian Morris * * SPDX-License-Identifier: Apache-2.0 */ #include #include #include #include #include #define LOG_LEVEL CONFIG_BT_HCI_DRIVER_LOG_LEVEL #include 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_set_dt(&bt_reset, 0); 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; }