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>
This commit is contained in:
parent
5a993b6d2a
commit
205932b24c
@ -43,6 +43,7 @@ int32_t notification_app(void* p);
|
|||||||
// On system start hooks declaration
|
// On system start hooks declaration
|
||||||
void nfc_cli_init();
|
void nfc_cli_init();
|
||||||
void subghz_cli_init();
|
void subghz_cli_init();
|
||||||
|
void bt_cli_init();
|
||||||
|
|
||||||
const FlipperApplication FLIPPER_SERVICES[] = {
|
const FlipperApplication FLIPPER_SERVICES[] = {
|
||||||
#ifdef SRV_CLI
|
#ifdef SRV_CLI
|
||||||
@ -208,6 +209,9 @@ const FlipperOnStartHook FLIPPER_ON_SYSTEM_START[] = {
|
|||||||
#ifdef APP_SUBGHZ
|
#ifdef APP_SUBGHZ
|
||||||
subghz_cli_init,
|
subghz_cli_init,
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef SRV_BT
|
||||||
|
bt_cli_init,
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
const size_t FLIPPER_ON_SYSTEM_START_COUNT =
|
const size_t FLIPPER_ON_SYSTEM_START_COUNT =
|
||||||
|
@ -26,8 +26,6 @@ Bt* bt_alloc() {
|
|||||||
bt->update_status_timer = osTimerNew(bt_update_statusbar, osTimerPeriodic, bt, NULL);
|
bt->update_status_timer = osTimerNew(bt_update_statusbar, osTimerPeriodic, bt, NULL);
|
||||||
osTimerStart(bt->update_status_timer, 4000);
|
osTimerStart(bt->update_status_timer, 4000);
|
||||||
bt->hopping_mode_timer = osTimerNew(bt_switch_freq, osTimerPeriodic, bt, NULL);
|
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->gui = furi_record_open("gui");
|
||||||
bt->menu = furi_record_open("menu");
|
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);
|
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() {
|
int32_t bt_task() {
|
||||||
Bt* bt = bt_alloc();
|
Bt* bt = bt_alloc();
|
||||||
|
|
||||||
@ -176,7 +166,7 @@ int32_t bt_task() {
|
|||||||
bt->state.type = BtStatusReady;
|
bt->state.type = BtStatusReady;
|
||||||
} else if(message.type == BtMessageTypeSetupTestPacketTx) {
|
} else if(message.type == BtMessageTypeSetupTestPacketTx) {
|
||||||
// Update packet test setup
|
// Update packet test setup
|
||||||
api_hal_bt_stop_packet_tx();
|
api_hal_bt_stop_packet_test();
|
||||||
with_view_model(
|
with_view_model(
|
||||||
bt->view_test_packet_tx, (BtViewTestPacketTxModel * model) {
|
bt->view_test_packet_tx, (BtViewTestPacketTxModel * model) {
|
||||||
model->type = bt->state.type;
|
model->type = bt->state.type;
|
||||||
@ -187,7 +177,7 @@ int32_t bt_task() {
|
|||||||
view_dispatcher_switch_to_view(bt->view_dispatcher, BtViewTestPacketTx);
|
view_dispatcher_switch_to_view(bt->view_dispatcher, BtViewTestPacketTx);
|
||||||
} else if(message.type == BtMessageTypeStartTestPacketTx) {
|
} else if(message.type == BtMessageTypeStartTestPacketTx) {
|
||||||
// Start sending packets
|
// 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(
|
with_view_model(
|
||||||
bt->view_test_packet_tx, (BtViewTestPacketTxModel * model) {
|
bt->view_test_packet_tx, (BtViewTestPacketTxModel * model) {
|
||||||
model->type = bt->state.type;
|
model->type = bt->state.type;
|
||||||
@ -198,7 +188,7 @@ int32_t bt_task() {
|
|||||||
view_dispatcher_switch_to_view(bt->view_dispatcher, BtViewTestPacketTx);
|
view_dispatcher_switch_to_view(bt->view_dispatcher, BtViewTestPacketTx);
|
||||||
} else if(message.type == BtMessageTypeStopTestPacketTx) {
|
} else if(message.type == BtMessageTypeStopTestPacketTx) {
|
||||||
// Stop test packet tx
|
// Stop test packet tx
|
||||||
api_hal_bt_stop_packet_tx();
|
api_hal_bt_stop_packet_test();
|
||||||
bt->state.type = BtStatusReady;
|
bt->state.type = BtStatusReady;
|
||||||
} else if(message.type == BtMessageTypeStartTestRx) {
|
} else if(message.type == BtMessageTypeStartTestRx) {
|
||||||
// Start test rx
|
// Start test rx
|
||||||
|
153
applications/bt/bt_cli.c
Executable file
153
applications/bt/bt_cli.c
Executable file
@ -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);
|
||||||
|
}
|
15
applications/bt/bt_cli.h
Normal file
15
applications/bt/bt_cli.h
Normal file
@ -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);
|
@ -22,7 +22,6 @@ struct Bt {
|
|||||||
BtState state;
|
BtState state;
|
||||||
osTimerId_t update_status_timer;
|
osTimerId_t update_status_timer;
|
||||||
osTimerId_t hopping_mode_timer;
|
osTimerId_t hopping_mode_timer;
|
||||||
Cli* cli;
|
|
||||||
Gui* gui;
|
Gui* gui;
|
||||||
ValueMutex* menu;
|
ValueMutex* menu;
|
||||||
// Status bar
|
// Status bar
|
||||||
@ -43,8 +42,6 @@ void bt_draw_statusbar_callback(Canvas* canvas, void* context);
|
|||||||
|
|
||||||
BtTestChannel bt_switch_channel(InputKey key, BtTestChannel inst_chan);
|
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_draw_statusbar_callback(Canvas* canvas, void* context);
|
||||||
|
|
||||||
void bt_menu_test_tone_tx(void* context);
|
void bt_menu_test_tone_tx(void* context);
|
||||||
|
@ -29,23 +29,32 @@ bool api_hal_bt_lock_flash();
|
|||||||
void api_hal_bt_unlock_flash();
|
void api_hal_bt_unlock_flash();
|
||||||
|
|
||||||
/** Start ble tone tx at given channel and power */
|
/** Start ble tone tx at given channel and power */
|
||||||
void api_hal_bt_start_tone_tx(uint8_t tx_channel, uint8_t power);
|
void api_hal_bt_start_tone_tx(uint8_t channel, uint8_t power);
|
||||||
|
|
||||||
/** Stop ble tone tx */
|
/** Stop ble tone tx */
|
||||||
void api_hal_bt_stop_tone_tx();
|
void api_hal_bt_stop_tone_tx();
|
||||||
|
|
||||||
/** Start sending ble packets at a given frequency and datarate */
|
/** Start sending ble packets at a given frequency and datarate */
|
||||||
void api_hal_bt_start_packet_tx(uint8_t frequency, uint8_t datarate);
|
void api_hal_bt_start_packet_tx(uint8_t channel, uint8_t pattern, uint8_t datarate);
|
||||||
|
|
||||||
/** Stop sending ble packets */
|
/** Stop sending ble packets */
|
||||||
void api_hal_bt_stop_packet_tx();
|
uint16_t api_hal_bt_stop_packet_test();
|
||||||
|
|
||||||
|
/** Start receiving packets */
|
||||||
|
void api_hal_bt_start_packet_rx(uint8_t channel, uint8_t datarate);
|
||||||
|
|
||||||
/** Set up the RF to listen to a given RF channel */
|
/** Set up the RF to listen to a given RF channel */
|
||||||
void api_hal_bt_start_rx(uint8_t frequency);
|
void api_hal_bt_start_rx(uint8_t channel);
|
||||||
|
|
||||||
/** Stop RF listenning */
|
/** Stop RF listenning */
|
||||||
void api_hal_bt_stop_rx();
|
void api_hal_bt_stop_rx();
|
||||||
|
|
||||||
|
/** Get RSSI */
|
||||||
|
float api_hal_bt_get_rssi();
|
||||||
|
|
||||||
|
/** Get number of transmitted packets */
|
||||||
|
uint32_t api_hal_bt_get_transmitted_packets();
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -82,26 +82,58 @@ void api_hal_bt_unlock_flash() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void api_hal_bt_start_tone_tx(uint8_t tx_channel, uint8_t power) {
|
void api_hal_bt_start_tone_tx(uint8_t channel, uint8_t power) {
|
||||||
aci_hal_set_tx_power_level(0, power);
|
aci_hal_set_tx_power_level(0, power);
|
||||||
aci_hal_tone_start(tx_channel, 0);
|
aci_hal_tone_start(channel, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void api_hal_bt_stop_tone_tx() {
|
void api_hal_bt_stop_tone_tx() {
|
||||||
aci_hal_tone_stop();
|
aci_hal_tone_stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
void api_hal_bt_start_packet_tx(uint8_t frequency, uint8_t datarate) {
|
void api_hal_bt_start_packet_tx(uint8_t channel, uint8_t pattern, uint8_t datarate) {
|
||||||
hci_le_enhanced_transmitter_test(frequency, 0x25, 2, datarate);
|
hci_le_enhanced_transmitter_test(channel, 0x25, pattern, datarate);
|
||||||
}
|
}
|
||||||
|
|
||||||
void api_hal_bt_stop_packet_tx() {
|
void api_hal_bt_start_packet_rx(uint8_t channel, uint8_t datarate) {
|
||||||
|
hci_le_enhanced_receiver_test(channel, datarate, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
uint16_t api_hal_bt_stop_packet_test() {
|
||||||
uint16_t num_of_packets;
|
uint16_t num_of_packets;
|
||||||
hci_le_test_end(&num_of_packets);
|
hci_le_test_end(&num_of_packets);
|
||||||
|
return num_of_packets;
|
||||||
}
|
}
|
||||||
|
|
||||||
void api_hal_bt_start_rx(uint8_t frequency) {
|
void api_hal_bt_start_rx(uint8_t channel) {
|
||||||
aci_hal_rx_start(frequency);
|
aci_hal_rx_start(channel);
|
||||||
|
}
|
||||||
|
|
||||||
|
float api_hal_bt_get_rssi() {
|
||||||
|
float val;
|
||||||
|
uint8_t rssi_raw[3];
|
||||||
|
aci_hal_read_raw_rssi(rssi_raw);
|
||||||
|
|
||||||
|
// Some ST magic with rssi
|
||||||
|
uint8_t agc = rssi_raw[2] & 0xFF;
|
||||||
|
int rssi = (rssi_raw[1] << 8 & 0xFF00) + (rssi_raw[1] & 0xFF);
|
||||||
|
if(rssi == 0 || agc > 11) {
|
||||||
|
val = 127;
|
||||||
|
} else {
|
||||||
|
val = agc * 6.0f - 127.0f;
|
||||||
|
while(rssi > 30) {
|
||||||
|
val += 6.0;
|
||||||
|
rssi >>=1;
|
||||||
|
}
|
||||||
|
val += (417 * rssi + 18080) >> 10;
|
||||||
|
}
|
||||||
|
return val;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t api_hal_bt_get_transmitted_packets() {
|
||||||
|
uint32_t packets = 0;
|
||||||
|
aci_hal_le_tx_test_packet_number(&packets);
|
||||||
|
return packets;
|
||||||
}
|
}
|
||||||
|
|
||||||
void api_hal_bt_stop_rx() {
|
void api_hal_bt_stop_rx() {
|
||||||
|
@ -82,26 +82,58 @@ void api_hal_bt_unlock_flash() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void api_hal_bt_start_tone_tx(uint8_t tx_channel, uint8_t power) {
|
void api_hal_bt_start_tone_tx(uint8_t channel, uint8_t power) {
|
||||||
aci_hal_set_tx_power_level(0, power);
|
aci_hal_set_tx_power_level(0, power);
|
||||||
aci_hal_tone_start(tx_channel, 0);
|
aci_hal_tone_start(channel, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void api_hal_bt_stop_tone_tx() {
|
void api_hal_bt_stop_tone_tx() {
|
||||||
aci_hal_tone_stop();
|
aci_hal_tone_stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
void api_hal_bt_start_packet_tx(uint8_t frequency, uint8_t datarate) {
|
void api_hal_bt_start_packet_tx(uint8_t channel, uint8_t pattern, uint8_t datarate) {
|
||||||
hci_le_enhanced_transmitter_test(frequency, 0x25, 2, datarate);
|
hci_le_enhanced_transmitter_test(channel, 0x25, pattern, datarate);
|
||||||
}
|
}
|
||||||
|
|
||||||
void api_hal_bt_stop_packet_tx() {
|
void api_hal_bt_start_packet_rx(uint8_t channel, uint8_t datarate) {
|
||||||
|
hci_le_enhanced_receiver_test(channel, datarate, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
uint16_t api_hal_bt_stop_packet_test() {
|
||||||
uint16_t num_of_packets;
|
uint16_t num_of_packets;
|
||||||
hci_le_test_end(&num_of_packets);
|
hci_le_test_end(&num_of_packets);
|
||||||
|
return num_of_packets;
|
||||||
}
|
}
|
||||||
|
|
||||||
void api_hal_bt_start_rx(uint8_t frequency) {
|
void api_hal_bt_start_rx(uint8_t channel) {
|
||||||
aci_hal_rx_start(frequency);
|
aci_hal_rx_start(channel);
|
||||||
|
}
|
||||||
|
|
||||||
|
float api_hal_bt_get_rssi() {
|
||||||
|
float val;
|
||||||
|
uint8_t rssi_raw[3];
|
||||||
|
aci_hal_read_raw_rssi(rssi_raw);
|
||||||
|
|
||||||
|
// Some ST magic with rssi
|
||||||
|
uint8_t agc = rssi_raw[2] & 0xFF;
|
||||||
|
int rssi = (rssi_raw[1] << 8 & 0xFF00) + (rssi_raw[1] & 0xFF);
|
||||||
|
if(rssi == 0 || agc > 11) {
|
||||||
|
val = 127;
|
||||||
|
} else {
|
||||||
|
val = agc * 6.0f - 127.0f;
|
||||||
|
while(rssi > 30) {
|
||||||
|
val += 6.0;
|
||||||
|
rssi >>=1;
|
||||||
|
}
|
||||||
|
val += (417 * rssi + 18080) >> 10;
|
||||||
|
}
|
||||||
|
return val;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t api_hal_bt_get_transmitted_packets() {
|
||||||
|
uint32_t packets = 0;
|
||||||
|
aci_hal_le_tx_test_packet_number(&packets);
|
||||||
|
return packets;
|
||||||
}
|
}
|
||||||
|
|
||||||
void api_hal_bt_stop_rx() {
|
void api_hal_bt_stop_rx() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user