mirror of
https://github.com/CovidBraceletPrj/CovidBracelet.git
synced 2025-01-10 05:04:26 +01:00
WIP
This commit is contained in:
parent
2befe3372c
commit
b9bb8b1922
@ -64,6 +64,9 @@ void main(void) {
|
|||||||
|
|
||||||
printk("Components initialized! Starting Tracing and Gatt...\n");
|
printk("Components initialized! Starting Tracing and Gatt...\n");
|
||||||
|
|
||||||
|
// We sleep for one second just
|
||||||
|
k_sleep(K_MSEC(1000));
|
||||||
|
|
||||||
do {
|
do {
|
||||||
uint32_t tracing_sleep_ms = tracing_run();
|
uint32_t tracing_sleep_ms = tracing_run();
|
||||||
uint32_t sync_sleep_ms = sync_service_run();
|
uint32_t sync_sleep_ms = sync_service_run();
|
||||||
|
@ -21,7 +21,7 @@ K_TIMER_DEFINE(sync_adv_timer, NULL, NULL);
|
|||||||
int sync_service_init(void) {
|
int sync_service_init(void) {
|
||||||
// We init the timers (which should run periodically!)
|
// We init the timers (which should run periodically!)
|
||||||
// we directly want to advertise ourselfs after the start -> should reduce unwanted delays
|
// we directly want to advertise ourselfs after the start -> should reduce unwanted delays
|
||||||
k_timer_start(&sync_adv_timer, K_NO_WAIT, K_MSEC(SYNC_ADV_INTERVAL_MS));
|
k_timer_start(&sync_adv_timer, K_MSEC(SYNC_ADV_INTERVAL_MS), K_MSEC(SYNC_ADV_INTERVAL_MS));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
154
src/tracing.c
154
src/tracing.c
@ -26,51 +26,64 @@
|
|||||||
typedef ENIntervalIdentifier ENIntervalIdentifier;
|
typedef ENIntervalIdentifier ENIntervalIdentifier;
|
||||||
|
|
||||||
#define RPI_ROTATION_MS (11*60*1000)
|
#define RPI_ROTATION_MS (11*60*1000)
|
||||||
#define SCAN_INTERVAL_MS (60*1000)
|
#define SCAN_INTERVAL_MS (4*1000)
|
||||||
#define SCAN_DURATION_MS 1000
|
#define SCAN_DURATION_MS 1000
|
||||||
#define ADV_INTERVAL_MS 220
|
#define ADV_INTERVAL_MS 250
|
||||||
|
|
||||||
|
|
||||||
K_TIMER_DEFINE(rpi_timer, NULL, NULL);
|
K_TIMER_DEFINE(rpi_timer, NULL, NULL);
|
||||||
K_TIMER_DEFINE(scan_timer, NULL, NULL);
|
K_TIMER_DEFINE(scan_timer, NULL, NULL);
|
||||||
K_TIMER_DEFINE(adv_timer, NULL, NULL);
|
|
||||||
|
|
||||||
static int on_rpi();
|
static int on_rpi();
|
||||||
static int on_scan();
|
static int on_scan();
|
||||||
static int on_adv();
|
|
||||||
|
|
||||||
|
#include <bluetooth/bluetooth.h>
|
||||||
|
#include <bluetooth/hci.h>
|
||||||
|
#include <bluetooth/hci_vs.h>
|
||||||
|
|
||||||
int tracing_init()
|
#include <sys/byteorder.h>
|
||||||
|
|
||||||
|
#define DEVICE_BEACON_TXPOWER_NUM 6
|
||||||
|
static const int8_t txp[DEVICE_BEACON_TXPOWER_NUM] = {0, -4, -8,
|
||||||
|
-16, -20, -40};
|
||||||
|
|
||||||
|
static void set_tx_power(int8_t tx_pwr_lvl)
|
||||||
{
|
{
|
||||||
// We init the timers (which should run periodically!)
|
struct bt_hci_cp_vs_write_tx_power_level *cp;
|
||||||
k_timer_start(&rpi_timer, K_NO_WAIT, K_MSEC(RPI_ROTATION_MS)); // we directly init the rpi timer, to be sure that this is triggered at the beginning
|
struct bt_hci_rp_vs_write_tx_power_level *rp;
|
||||||
k_timer_start(&scan_timer, K_MSEC(SCAN_INTERVAL_MS), K_MSEC(SCAN_INTERVAL_MS));
|
struct net_buf *buf, *rsp = NULL;
|
||||||
k_timer_start(&adv_timer, K_MSEC(ADV_INTERVAL_MS), K_MSEC(ADV_INTERVAL_MS));
|
int err;
|
||||||
|
|
||||||
|
buf = bt_hci_cmd_create(BT_HCI_OP_VS_WRITE_TX_POWER_LEVEL,
|
||||||
return 0;
|
sizeof(*cp));
|
||||||
|
if (!buf) {
|
||||||
|
printk("Unable to allocate command buffer\n");
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t tracing_run()
|
cp = net_buf_add(buf, sizeof(*cp));
|
||||||
{
|
cp->handle = sys_cpu_to_le16(0);
|
||||||
if (k_timer_status_get(&rpi_timer) > 0) {
|
cp->handle_type = BT_HCI_VS_LL_HANDLE_TYPE_ADV;
|
||||||
on_rpi();
|
cp->tx_power_level = tx_pwr_lvl;
|
||||||
|
|
||||||
|
err = bt_hci_cmd_send_sync(BT_HCI_OP_VS_WRITE_TX_POWER_LEVEL,
|
||||||
|
buf, &rsp);
|
||||||
|
if (err) {
|
||||||
|
uint8_t reason = rsp ?
|
||||||
|
((struct bt_hci_rp_vs_write_tx_power_level *)
|
||||||
|
rsp->data)->status : 0;
|
||||||
|
printk("Set Tx power err: %d reason 0x%02x\n", err, reason);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (k_timer_status_get(&scan_timer) > 0) {
|
rp = (void *)rsp->data;
|
||||||
on_scan();
|
printk("Actual Tx Power: %d\n", rp->selected_tx_power);
|
||||||
|
|
||||||
|
net_buf_unref(rsp);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (k_timer_status_get(&adv_timer) > 0) {
|
|
||||||
on_adv();
|
|
||||||
}
|
|
||||||
|
|
||||||
// we return the minimum timer time so that main can sleep
|
|
||||||
return MIN( k_timer_remaining_get(&rpi_timer),
|
|
||||||
MIN(k_timer_remaining_get(&scan_timer),
|
|
||||||
k_timer_remaining_get(&adv_timer)));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
static int cur_tx_pwr = 0;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -99,11 +112,76 @@ static covid_adv_svd_t covid_adv_svd = {
|
|||||||
//do not initialiuze the rest of the packet, will write this later
|
//do not initialiuze the rest of the packet, will write this later
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
static struct bt_data ad[] = {
|
static struct bt_data ad[] = {
|
||||||
BT_DATA_BYTES(BT_DATA_FLAGS, (BT_LE_AD_GENERAL | BT_LE_AD_NO_BREDR)),
|
BT_DATA_BYTES(BT_DATA_FLAGS, (BT_LE_AD_GENERAL | BT_LE_AD_NO_BREDR)),
|
||||||
BT_DATA_BYTES(BT_DATA_UUID16_ALL, 0x6f, 0xfd), //0xFD6F Exposure Notification Service
|
BT_DATA_BYTES(BT_DATA_UUID16_ALL, 0x6f, 0xfd), //0xFD6F Exposure Notification Service
|
||||||
BT_DATA(BT_DATA_SVC_DATA16, &covid_adv_svd, sizeof(covid_adv_svd_t))};
|
BT_DATA(BT_DATA_SVC_DATA16, &covid_adv_svd, sizeof(covid_adv_svd_t))};
|
||||||
|
|
||||||
|
int adv_start() {
|
||||||
|
|
||||||
|
return bt_le_adv_start(BT_LE_ADV_PARAM(0, (ADV_INTERVAL_MS-10)/0.625, (ADV_INTERVAL_MS+10)/0.625, NULL), ad, ARRAY_SIZE(ad), NULL, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
int adv_stop() {
|
||||||
|
return bt_le_adv_stop();
|
||||||
|
}
|
||||||
|
|
||||||
|
int tracing_init()
|
||||||
|
{
|
||||||
|
// We init the timers (which should run periodically!)
|
||||||
|
k_timer_start(&rpi_timer, K_NO_WAIT, K_MSEC(RPI_ROTATION_MS)); // we directly init the rpi timer, to be sure that this is triggered at the beginning
|
||||||
|
k_timer_start(&scan_timer, K_MSEC(SCAN_INTERVAL_MS), K_MSEC(SCAN_INTERVAL_MS));
|
||||||
|
|
||||||
|
|
||||||
|
set_tx_power(txp[cur_tx_pwr]);
|
||||||
|
|
||||||
|
int err = 0;
|
||||||
|
err = adv_start();
|
||||||
|
if (err)
|
||||||
|
{
|
||||||
|
printk("Advertising failed to start (err %d)\n", err);
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t tracing_run()
|
||||||
|
{
|
||||||
|
if (k_timer_status_get(&rpi_timer) > 0) {
|
||||||
|
on_rpi();
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: Randomize the adv power!
|
||||||
|
|
||||||
|
if (k_timer_status_get(&scan_timer) > 0) {
|
||||||
|
int err = adv_stop();
|
||||||
|
|
||||||
|
if (err)
|
||||||
|
{
|
||||||
|
printk("Advertising failed to stop (err %d)\n", err);
|
||||||
|
}
|
||||||
|
|
||||||
|
on_scan();
|
||||||
|
|
||||||
|
cur_tx_pwr = (cur_tx_pwr +1) % DEVICE_BEACON_TXPOWER_NUM;
|
||||||
|
set_tx_power(txp[cur_tx_pwr]);
|
||||||
|
|
||||||
|
|
||||||
|
adv_start();
|
||||||
|
}
|
||||||
|
|
||||||
|
// we return the minimum timer time so that main can sleep
|
||||||
|
return MIN( k_timer_remaining_get(&rpi_timer), k_timer_remaining_get(&scan_timer));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int on_rpi() {
|
int on_rpi() {
|
||||||
|
|
||||||
@ -158,12 +236,11 @@ int on_rpi() {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static const struct bt_le_scan_param scan_param = {
|
static const struct bt_le_scan_param scan_param = {
|
||||||
.type = BT_HCI_LE_SCAN_PASSIVE,
|
.type = BT_HCI_LE_SCAN_PASSIVE,
|
||||||
.options = BT_LE_SCAN_OPT_FILTER_DUPLICATE,
|
.options = BT_LE_SCAN_OPT_FILTER_DUPLICATE,
|
||||||
.interval = 0x0010, //Scan Interval (N * 0.625 ms), TODO: set to correct interval
|
.interval = 0x0C80, //Scan Interval (N * 0.625 ms), TODO: set to correct interval
|
||||||
.window = 0x0010, //Scan Window (N * 0.625 ms), TODO: set to correct interval
|
.window = 0x0C80, //Scan Window (N * 0.625 ms), TODO: set to correct interval
|
||||||
};
|
};
|
||||||
|
|
||||||
static void scan_cb(const bt_addr_le_t *addr, int8_t rssi, uint8_t adv_type, struct net_buf_simple *buf)
|
static void scan_cb(const bt_addr_le_t *addr, int8_t rssi, uint8_t adv_type, struct net_buf_simple *buf)
|
||||||
@ -234,22 +311,3 @@ int on_scan() {
|
|||||||
printk("Scanning done... %u devices found\n", get_num_records()-num_devs);
|
printk("Scanning done... %u devices found\n", get_num_records()-num_devs);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int on_adv() {
|
|
||||||
int err = 0;
|
|
||||||
err = bt_le_adv_start(BT_LE_ADV_PARAM(0, (ADV_INTERVAL_MS-10)/0.625, (ADV_INTERVAL_MS+10)/0.625, NULL), ad, ARRAY_SIZE(ad), NULL, 0);
|
|
||||||
if (err)
|
|
||||||
{
|
|
||||||
printk("Advertising failed to start (err %d)\n", err);
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
k_yield();
|
|
||||||
err = bt_le_adv_stop();
|
|
||||||
if (err)
|
|
||||||
{
|
|
||||||
printk("Advertising failed to stop (err %d)\n", err);
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
@ -44,6 +44,8 @@ CONFIG_TIMING_FUNCTIONS=y
|
|||||||
|
|
||||||
CONFIG_LOG=y
|
CONFIG_LOG=y
|
||||||
|
|
||||||
|
CONFIG_BT_CTLR_TX_PWR_DYNAMIC_CONTROL=y
|
||||||
|
|
||||||
# # Run protobuf unpack tests at startup
|
# # Run protobuf unpack tests at startup
|
||||||
# CONFIG_TEST_UNPACK_KEYS_N=12
|
# CONFIG_TEST_UNPACK_KEYS_N=12
|
||||||
# CONFIG_TEST_UNPACK_KEYS=y
|
# CONFIG_TEST_UNPACK_KEYS=y
|
||||||
|
Loading…
x
Reference in New Issue
Block a user