2019-03-26 13:53:17 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2019 Freie Universität Berlin
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup examples
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Example for using NimBLE as a BLE scanner
|
|
|
|
*
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
2021-08-03 11:54:25 +02:00
|
|
|
#include "timex.h"
|
|
|
|
#include "ztimer.h"
|
2019-03-26 13:53:17 +01:00
|
|
|
#include "shell.h"
|
|
|
|
#include "shell_commands.h"
|
|
|
|
|
|
|
|
#include "nimble_scanner.h"
|
|
|
|
#include "nimble_scanlist.h"
|
|
|
|
|
2021-09-13 22:00:22 +02:00
|
|
|
/* default scan interval */
|
|
|
|
#define DEFAULT_SCAN_INTERVAL_MS 30
|
|
|
|
|
2019-03-26 13:53:17 +01:00
|
|
|
/* default scan duration (1s) */
|
2021-08-03 11:54:25 +02:00
|
|
|
#define DEFAULT_DURATION_MS (1 * MS_PER_SEC)
|
2019-03-26 13:53:17 +01:00
|
|
|
|
|
|
|
int _cmd_scan(int argc, char **argv)
|
|
|
|
{
|
2021-08-03 11:54:25 +02:00
|
|
|
uint32_t timeout = DEFAULT_DURATION_MS;
|
2019-03-26 13:53:17 +01:00
|
|
|
|
|
|
|
if ((argc == 2) && (memcmp(argv[1], "help", 4) == 0)) {
|
|
|
|
printf("usage: %s [timeout in ms]\n", argv[0]);
|
2021-09-13 22:00:22 +02:00
|
|
|
|
2019-03-26 13:53:17 +01:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (argc >= 2) {
|
2021-08-03 11:54:25 +02:00
|
|
|
timeout = atoi(argv[1]);
|
2019-03-26 13:53:17 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
nimble_scanlist_clear();
|
2021-09-13 22:00:22 +02:00
|
|
|
printf("Scanning for %"PRIu32" ms now ...\n", timeout);
|
2019-03-26 13:53:17 +01:00
|
|
|
nimble_scanner_start();
|
2021-08-03 11:54:25 +02:00
|
|
|
ztimer_sleep(ZTIMER_MSEC, timeout);
|
2021-09-13 22:00:22 +02:00
|
|
|
nimble_scanner_stop();
|
|
|
|
puts("Done, results:");
|
2019-03-26 13:53:17 +01:00
|
|
|
nimble_scanlist_print();
|
|
|
|
puts("");
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static const shell_command_t _commands[] = {
|
2019-04-29 11:41:21 +02:00
|
|
|
{ "scan", "trigger a BLE scan", _cmd_scan },
|
2019-03-26 13:53:17 +01:00
|
|
|
{ NULL, NULL, NULL }
|
|
|
|
};
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
puts("NimBLE Scanner Example Application");
|
|
|
|
puts("Type `scan help` for more information");
|
|
|
|
|
|
|
|
/* in this example, we want Nimble to scan 'full time', so we set the
|
|
|
|
* window equal the interval */
|
2021-09-13 22:00:22 +02:00
|
|
|
nimble_scanner_cfg_t params = {
|
|
|
|
.itvl_ms = DEFAULT_SCAN_INTERVAL_MS,
|
|
|
|
.win_ms = DEFAULT_SCAN_INTERVAL_MS,
|
|
|
|
#if IS_USED(MODULE_NIMBLE_PHY_CODED)
|
|
|
|
.flags = NIMBLE_SCANNER_PHY_1M | NIMBLE_SCANNER_PHY_CODED,
|
|
|
|
#else
|
|
|
|
.flags = NIMBLE_SCANNER_PHY_1M,
|
|
|
|
#endif
|
2019-03-26 13:53:17 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
/* initialize the nimble scanner */
|
|
|
|
nimble_scanlist_init();
|
2021-09-13 22:00:22 +02:00
|
|
|
nimble_scanner_init(¶ms, nimble_scanlist_update);
|
2019-03-26 13:53:17 +01:00
|
|
|
|
|
|
|
/* start shell */
|
|
|
|
char line_buf[SHELL_DEFAULT_BUFSIZE];
|
|
|
|
shell_run(_commands, line_buf, SHELL_DEFAULT_BUFSIZE);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|