Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/ClusterM/flipperzero-firmware.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorgornekich <n.gorbadey@gmail.com>2021-05-29 01:57:11 +0300
committerGitHub <noreply@github.com>2021-05-29 01:57:11 +0300
commit205932b24cca15852ae153dc46ec3707ee59e06c (patch)
tree778a9e43ca58b52de6dcfe73e4f6548559856779 /applications/bt
parent5a993b6d2aec0b3b4228ddce776fdec789a83b34 (diff)
Add BLE CLI tests (#502)
* bt: introduce bt CLI commands * api-hal-bt: add get rssi * bt: fix cli commands * bt: fix typos * Bt: add missing newline in console message Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
Diffstat (limited to 'applications/bt')
-rw-r--r--applications/bt/bt.c16
-rwxr-xr-xapplications/bt/bt_cli.c153
-rw-r--r--applications/bt/bt_cli.h15
-rw-r--r--applications/bt/bt_i.h3
4 files changed, 171 insertions, 16 deletions
diff --git a/applications/bt/bt.c b/applications/bt/bt.c
index f3a97cff..8add7b43 100644
--- a/applications/bt/bt.c
+++ b/applications/bt/bt.c
@@ -26,8 +26,6 @@ Bt* bt_alloc() {
bt->update_status_timer = osTimerNew(bt_update_statusbar, osTimerPeriodic, bt, NULL);
osTimerStart(bt->update_status_timer, 4000);
bt->hopping_mode_timer = osTimerNew(bt_switch_freq, osTimerPeriodic, bt, NULL);
- bt->cli = furi_record_open("cli");
- cli_add_command(bt->cli, "bt_info", bt_cli_info, bt);
bt->gui = furi_record_open("gui");
bt->menu = furi_record_open("menu");
@@ -134,14 +132,6 @@ void bt_menu_start_app(void* context) {
furi_check(osMessageQueuePut(bt->message_queue, &message, 0, osWaitForever) == osOK);
}
-void bt_cli_info(Cli* cli, string_t args, void* context) {
- string_t buffer;
- string_init(buffer);
- api_hal_bt_dump_state(buffer);
- printf(string_get_cstr(buffer));
- string_clear(buffer);
-}
-
int32_t bt_task() {
Bt* bt = bt_alloc();
@@ -176,7 +166,7 @@ int32_t bt_task() {
bt->state.type = BtStatusReady;
} else if(message.type == BtMessageTypeSetupTestPacketTx) {
// Update packet test setup
- api_hal_bt_stop_packet_tx();
+ api_hal_bt_stop_packet_test();
with_view_model(
bt->view_test_packet_tx, (BtViewTestPacketTxModel * model) {
model->type = bt->state.type;
@@ -187,7 +177,7 @@ int32_t bt_task() {
view_dispatcher_switch_to_view(bt->view_dispatcher, BtViewTestPacketTx);
} else if(message.type == BtMessageTypeStartTestPacketTx) {
// Start sending packets
- api_hal_bt_start_packet_tx(message.param.channel, message.param.datarate);
+ api_hal_bt_start_packet_tx(message.param.channel, 1, message.param.datarate);
with_view_model(
bt->view_test_packet_tx, (BtViewTestPacketTxModel * model) {
model->type = bt->state.type;
@@ -198,7 +188,7 @@ int32_t bt_task() {
view_dispatcher_switch_to_view(bt->view_dispatcher, BtViewTestPacketTx);
} else if(message.type == BtMessageTypeStopTestPacketTx) {
// Stop test packet tx
- api_hal_bt_stop_packet_tx();
+ api_hal_bt_stop_packet_test();
bt->state.type = BtStatusReady;
} else if(message.type == BtMessageTypeStartTestRx) {
// Start test rx
diff --git a/applications/bt/bt_cli.c b/applications/bt/bt_cli.c
new file mode 100755
index 00000000..815e48f6
--- /dev/null
+++ b/applications/bt/bt_cli.c
@@ -0,0 +1,153 @@
+#include "bt_cli.h"
+#include <furi.h>
+#include <api-hal.h>
+
+void bt_cli_init() {
+ Cli* cli = furi_record_open("cli");
+
+ cli_add_command(cli, "bt_info", bt_cli_command_info, NULL);
+ cli_add_command(cli, "bt_tx_carrier", bt_cli_command_carrier_tx, NULL);
+ cli_add_command(cli, "bt_rx_carrier", bt_cli_command_carrier_rx, NULL);
+ cli_add_command(cli, "bt_tx_pt", bt_cli_command_packet_tx, NULL);
+ cli_add_command(cli, "bt_rx_pt", bt_cli_command_packet_rx, NULL);
+
+ furi_record_close("cli");
+}
+
+void bt_cli_command_info(Cli* cli, string_t args, void* context) {
+ string_t buffer;
+ string_init(buffer);
+ api_hal_bt_dump_state(buffer);
+ printf(string_get_cstr(buffer));
+ string_clear(buffer);
+}
+
+void bt_cli_command_carrier_tx(Cli* cli, string_t args, void* context) {
+ uint16_t channel;
+ uint16_t power;
+ int ret = sscanf(string_get_cstr(args), "%hu %hu", &channel, &power);
+ if(ret != 2) {
+ printf("sscanf returned %d, channel: %hu, power: %hu\r\n", ret, channel, power);
+ cli_print_usage("bt_tx_carrier", "<Channel number> <Power>", string_get_cstr(args));
+ return;
+ }
+ if(channel > 39) {
+ printf("Channel number must be in 0...39 range, not %hu\r\n", channel);
+ return;
+ }
+ if(power > 6) {
+ printf("Power must be in 0...6 dB range, not %hu\r\n", power);
+ return;
+ }
+ printf("Transmitting carrier at %hu channel at %hu dB power\r\n", channel, power);
+ printf("Press CTRL+C to stop\r\n");
+ api_hal_bt_start_tone_tx(channel, 0x19 + power);
+
+ while(!cli_cmd_interrupt_received(cli)) {
+ osDelay(250);
+ }
+ api_hal_bt_stop_tone_tx();
+}
+
+void bt_cli_command_carrier_rx(Cli* cli, string_t args, void* context) {
+ uint16_t channel;
+ int ret = sscanf(string_get_cstr(args), "%hu", &channel);
+ if(ret != 1) {
+ printf("sscanf returned %d, channel: %hu\r\n", ret, channel);
+ cli_print_usage("bt_rx_carrier", "<Channel number>", string_get_cstr(args));
+ return;
+ }
+ if(channel > 39) {
+ printf("Channel number must be in 0...39 range, not %hu\r\n", channel);
+ return;
+ }
+ printf("Receiving carrier at %hu channel\r\n", channel);
+ printf("Press CTRL+C to stop\r\n");
+ api_hal_bt_start_packet_rx(channel, 1);
+
+ float rssi_raw = 0;
+ while(!cli_cmd_interrupt_received(cli)) {
+ osDelay(250);
+ rssi_raw = api_hal_bt_get_rssi();
+ printf("RSSI: %03.1f dB\r", rssi_raw);
+ fflush(stdout);
+ }
+ api_hal_bt_stop_packet_test();
+}
+
+void bt_cli_command_packet_tx(Cli* cli, string_t args, void* context) {
+ uint16_t channel;
+ uint16_t pattern;
+ uint16_t datarate;
+ int ret = sscanf(string_get_cstr(args), "%hu %hu %hu", &channel, &pattern, &datarate);
+ if(ret != 3) {
+ printf("sscanf returned %d, channel: %hu %hu %hu\r\n", ret, channel, pattern, datarate);
+ cli_print_usage(
+ "bt_tx_pt", "<Channel number> <Pattern> <Datarate>", string_get_cstr(args));
+ return;
+ }
+ if(channel > 39) {
+ printf("Channel number must be in 0...39 range, not %hu\r\n", channel);
+ return;
+ }
+ if(pattern > 5) {
+ printf("Pattern must be in 0...5 range, not %hu\r\n", pattern);
+ printf("0 - Pseudo-Random bit sequence 9\r\n");
+ printf("1 - Pattern of alternating bits '11110000'\r\n");
+ printf("2 - Pattern of alternating bits '10101010'\r\n");
+ printf("3 - Pseudo-Random bit sequence 15\r\n");
+ printf("4 - Pattern of All '1' bits\r\n");
+ printf("5 - Pattern of All '0' bits\r\n");
+ return;
+ }
+ if(datarate < 1 || datarate > 2) {
+ printf("Datarate must be in 1 or 2 Mb, not %hu\r\n", datarate);
+ return;
+ }
+
+ printf(
+ "Transmitting %hu pattern packet at %hu channel at %hu M datarate\r\n",
+ pattern,
+ channel,
+ datarate);
+ printf("Press CTRL+C to stop\r\n");
+ api_hal_bt_start_packet_tx(channel, pattern, datarate);
+
+ while(!cli_cmd_interrupt_received(cli)) {
+ osDelay(250);
+ }
+ api_hal_bt_stop_packet_test();
+ printf("Transmitted %lu packets", api_hal_bt_get_transmitted_packets());
+}
+
+void bt_cli_command_packet_rx(Cli* cli, string_t args, void* context) {
+ uint16_t channel;
+ uint16_t datarate;
+ int ret = sscanf(string_get_cstr(args), "%hu %hu", &channel, &datarate);
+ if(ret != 2) {
+ printf("sscanf returned %d, channel: %hu datarate: %hu\r\n", ret, channel, datarate);
+ cli_print_usage("bt_rx_pt", "<Channel number> <Datarate>", string_get_cstr(args));
+ return;
+ }
+ if(channel > 39) {
+ printf("Channel number must be in 0...39 range, not %hu\r\n", channel);
+ return;
+ }
+ if(datarate < 1 || datarate > 2) {
+ printf("Datarate must be in 1 or 2 Mb, not %hu\r\n", datarate);
+ return;
+ }
+ printf("Receiving packets at %hu channel at %hu M datarate\r\n", channel, datarate);
+ printf("Press CTRL+C to stop\r\n");
+ api_hal_bt_start_packet_rx(channel, datarate);
+
+ float rssi_raw = 0;
+ while(!cli_cmd_interrupt_received(cli)) {
+ osDelay(250);
+ rssi_raw = api_hal_bt_get_rssi();
+ printf("RSSI: %03.1f dB\r", rssi_raw);
+ fflush(stdout);
+ }
+ uint16_t packets_received = api_hal_bt_stop_packet_test();
+ printf("Received %hu packets", packets_received);
+}
diff --git a/applications/bt/bt_cli.h b/applications/bt/bt_cli.h
new file mode 100644
index 00000000..1aa76d68
--- /dev/null
+++ b/applications/bt/bt_cli.h
@@ -0,0 +1,15 @@
+#pragma once
+
+#include <cli/cli.h>
+
+void bt_cli_init();
+
+void bt_cli_command_info(Cli* cli, string_t args, void* context);
+
+void bt_cli_command_carrier_tx(Cli* cli, string_t args, void* context);
+
+void bt_cli_command_carrier_rx(Cli* cli, string_t args, void* context);
+
+void bt_cli_command_packet_tx(Cli* cli, string_t args, void* context);
+
+void bt_cli_command_packet_rx(Cli* cli, string_t args, void* context);
diff --git a/applications/bt/bt_i.h b/applications/bt/bt_i.h
index 2a5ae26c..78565ce4 100644
--- a/applications/bt/bt_i.h
+++ b/applications/bt/bt_i.h
@@ -22,7 +22,6 @@ struct Bt {
BtState state;
osTimerId_t update_status_timer;
osTimerId_t hopping_mode_timer;
- Cli* cli;
Gui* gui;
ValueMutex* menu;
// Status bar
@@ -43,8 +42,6 @@ void bt_draw_statusbar_callback(Canvas* canvas, void* context);
BtTestChannel bt_switch_channel(InputKey key, BtTestChannel inst_chan);
-void bt_cli_info(Cli* cli, string_t args, void* context);
-
void bt_draw_statusbar_callback(Canvas* canvas, void* context);
void bt_menu_test_tone_tx(void* context);