1 /* main.c - Application main entry point */
2
3 /*
4 * Copyright (c) 2023 Nordic Semiconductor ASA
5 *
6 * SPDX-License-Identifier: Apache-2.0
7 */
8
9 #include <zephyr/kernel.h>
10 #include <zephyr/device.h>
11
12 #include <zephyr/drivers/gpio.h>
13
14 #include <zephyr/sys/util.h>
15 #include <zephyr/sys/printk.h>
16
17 #include <zephyr/bluetooth/conn.h>
18
19 #include <zephyr/logging/log.h>
20
21 #include "common.h"
22
23 LOG_MODULE_DECLARE(ead_peripheral_sample, CONFIG_BT_EAD_LOG_LEVEL);
24
25 /*
26 * Get button configuration from the devicetree sw0 alias. This is mandatory.
27 */
28 #define SW0_NODE DT_ALIAS(sw0)
29 #if !DT_NODE_HAS_STATUS_OKAY(SW0_NODE)
30 #error "Unsupported board: sw0 devicetree alias is not defined"
31 #endif
32 static const struct gpio_dt_spec button = GPIO_DT_SPEC_GET_OR(SW0_NODE, gpios, {0});
33 static struct gpio_callback button_cb_data;
34
35 extern int run_peripheral_sample(int get_passkey_confirmation(struct bt_conn *conn));
36
37 static struct k_poll_signal button_pressed_signal;
38
button_pressed(const struct device * dev,struct gpio_callback * cb,uint32_t pins)39 static void button_pressed(const struct device *dev, struct gpio_callback *cb, uint32_t pins)
40 {
41 LOG_DBG("Button pressed...");
42
43 k_poll_signal_raise(&button_pressed_signal, 0);
44 k_sleep(K_SECONDS(1));
45 k_poll_signal_reset(&button_pressed_signal);
46 }
47
get_passkey_confirmation(struct bt_conn * conn)48 static int get_passkey_confirmation(struct bt_conn *conn)
49 {
50 int err;
51
52 printk("Confirm passkey by pressing button at %s pin %d...\n", button.port->name,
53 button.pin);
54
55 await_signal(&button_pressed_signal);
56
57 err = bt_conn_auth_passkey_confirm(conn);
58 if (err) {
59 LOG_DBG("Failed to confirm passkey.");
60 return -1;
61 }
62
63 printk("Passkey confirmed.\n");
64
65 return 0;
66 }
67
setup_btn(void)68 static int setup_btn(void)
69 {
70 int ret;
71
72 k_poll_signal_init(&button_pressed_signal);
73
74 if (!gpio_is_ready_dt(&button)) {
75 LOG_ERR("Error: button device %s is not ready", button.port->name);
76 return -1;
77 }
78
79 ret = gpio_pin_configure_dt(&button, GPIO_INPUT);
80 if (ret != 0) {
81 LOG_ERR("Error %d: failed to configure %s pin %d", ret, button.port->name,
82 button.pin);
83 return -1;
84 }
85
86 ret = gpio_pin_interrupt_configure_dt(&button, GPIO_INT_EDGE_TO_ACTIVE);
87 if (ret != 0) {
88 LOG_ERR("Error %d: failed to configure interrupt on %s pin %d", ret,
89 button.port->name, button.pin);
90 return -1;
91 }
92
93 gpio_init_callback(&button_cb_data, button_pressed, BIT(button.pin));
94 gpio_add_callback(button.port, &button_cb_data);
95 LOG_DBG("Set up button at %s pin %d", button.port->name, button.pin);
96
97 return 0;
98 }
99
main(void)100 int main(void)
101 {
102 int err;
103
104 err = setup_btn();
105 if (err) {
106 return 0;
107 }
108
109 LOG_DBG("Starting peripheral sample...");
110
111 (void)run_peripheral_sample(get_passkey_confirmation);
112 return 0;
113 }
114