As both C and C++ standards require applications running under an OS to
return 'int', adapt that for Zephyr to align with those standard. This also
eliminates errors when building with clang when not using -ffreestanding,
and reduces the need for compiler flags to silence warnings for both clang
and gcc.
Most of these changes were automated using coccinelle with the following
script:
@@
@@
- void
+ int
main(...) {
...
- return;
+ return 0;
...
}
Approximately 40 files had to be edited by hand as coccinelle was unable to
fix them.
Signed-off-by: Keith Packard <keithp@keithp.com>
90 lines
2.2 KiB
C
90 lines
2.2 KiB
C
/* main.c - Application main entry point */
|
|
|
|
/*
|
|
* Copyright (c) 2015-2016 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
#include <zephyr/types.h>
|
|
#include <stddef.h>
|
|
#include <zephyr/sys/printk.h>
|
|
#include <zephyr/sys/util.h>
|
|
|
|
#include <zephyr/bluetooth/bluetooth.h>
|
|
#include <zephyr/bluetooth/hci.h>
|
|
|
|
#define DEVICE_NAME CONFIG_BT_DEVICE_NAME
|
|
#define DEVICE_NAME_LEN (sizeof(DEVICE_NAME) - 1)
|
|
|
|
/*
|
|
* Set Advertisement data. Based on the Eddystone specification:
|
|
* https://github.com/google/eddystone/blob/master/protocol-specification.md
|
|
* https://github.com/google/eddystone/tree/master/eddystone-url
|
|
*/
|
|
static const struct bt_data ad[] = {
|
|
BT_DATA_BYTES(BT_DATA_FLAGS, BT_LE_AD_NO_BREDR),
|
|
BT_DATA_BYTES(BT_DATA_UUID16_ALL, 0xaa, 0xfe),
|
|
BT_DATA_BYTES(BT_DATA_SVC_DATA16,
|
|
0xaa, 0xfe, /* Eddystone UUID */
|
|
0x10, /* Eddystone-URL frame type */
|
|
0x00, /* Calibrated Tx power at 0m */
|
|
0x00, /* URL Scheme Prefix http://www. */
|
|
'z', 'e', 'p', 'h', 'y', 'r',
|
|
'p', 'r', 'o', 'j', 'e', 'c', 't',
|
|
0x08) /* .org */
|
|
};
|
|
|
|
/* Set Scan Response data */
|
|
static const struct bt_data sd[] = {
|
|
BT_DATA(BT_DATA_NAME_COMPLETE, DEVICE_NAME, DEVICE_NAME_LEN),
|
|
};
|
|
|
|
static void bt_ready(int err)
|
|
{
|
|
char addr_s[BT_ADDR_LE_STR_LEN];
|
|
bt_addr_le_t addr = {0};
|
|
size_t count = 1;
|
|
|
|
if (err) {
|
|
printk("Bluetooth init failed (err %d)\n", err);
|
|
return;
|
|
}
|
|
|
|
printk("Bluetooth initialized\n");
|
|
|
|
/* Start advertising */
|
|
err = bt_le_adv_start(BT_LE_ADV_NCONN_IDENTITY, ad, ARRAY_SIZE(ad),
|
|
sd, ARRAY_SIZE(sd));
|
|
if (err) {
|
|
printk("Advertising failed to start (err %d)\n", err);
|
|
return;
|
|
}
|
|
|
|
|
|
/* For connectable advertising you would use
|
|
* bt_le_oob_get_local(). For non-connectable non-identity
|
|
* advertising an non-resolvable private address is used;
|
|
* there is no API to retrieve that.
|
|
*/
|
|
|
|
bt_id_get(&addr, &count);
|
|
bt_addr_le_to_str(&addr, addr_s, sizeof(addr_s));
|
|
|
|
printk("Beacon started, advertising as %s\n", addr_s);
|
|
}
|
|
|
|
int main(void)
|
|
{
|
|
int err;
|
|
|
|
printk("Starting Beacon Demo\n");
|
|
|
|
/* Initialize the Bluetooth Subsystem */
|
|
err = bt_enable(bt_ready);
|
|
if (err) {
|
|
printk("Bluetooth init failed (err %d)\n", err);
|
|
}
|
|
return 0;
|
|
}
|