pinebuds/services/through_put/app_through_put.cpp

282 lines
9.6 KiB
C++
Raw Permalink Normal View History

#include "app_through_put.h"
2022-08-15 04:20:27 -05:00
#include "app_ai_if.h"
#include "app_ai_if_config.h"
#include "app_ai_if_custom_ui.h"
#include "app_ai_if_thirdparty.h"
#include "app_ai_manager_api.h"
#include "app_ai_tws.h"
#include "cmsis_os.h"
#include "hal_trace.h"
#include <stdlib.h>
2022-08-15 04:20:27 -05:00
#ifdef __AI_VOICE__
#include "ai_control.h"
#include "ai_manager.h"
2022-08-15 04:20:27 -05:00
#include "ai_thread.h"
#include "app_ai_voice.h"
#endif
static THROUGHPUT_TEST_ENV_T throughputTestEnv;
static THROUGHPUT_TEST_CONFIG_T throughputTestConfig;
static uint32_t app_throughput_test_transmission_handler(void *param1,
uint32_t param2);
static APP_THROUGHPUT_CMD_INSTANCE_T *
find_throughput_instance_by_code(uint16_t cmdCode) {
for (uint32_t index = 0; index < APP_THROUGHPUT_CMD_INSTANCE_NUMBER;
index++) {
if (through_put_table[index].cmdCode == cmdCode) {
return &through_put_table[index];
2022-08-15 04:20:27 -05:00
}
}
2022-08-15 04:20:27 -05:00
return NULL;
2022-08-15 04:20:27 -05:00
}
bool app_throughput_send_command(APP_THROUGHPUT_CMD_CODE_E cmdCode,
uint8_t *ptrParam, uint32_t paramLen) {
APP_THROUGHPUT_CMD_PAYLOAD_T payload;
uint16_t cmd_len = 0;
2022-08-15 04:20:27 -05:00
if (THROUGHPUT_DATA_MAX_SIZE < paramLen) {
TRACE(1, "%s error ", __func__);
return false;
}
2022-08-15 04:20:27 -05:00
payload.cmdCode = cmdCode;
payload.paramLen = paramLen;
memcpy(payload.param, ptrParam, paramLen);
2022-08-15 04:20:27 -05:00
cmd_len = (uint32_t)THROUGHPUT_CMD_PAYLOAD_HEADER_LEN + payload.paramLen;
app_ai_if_custom_ui_send_cmd((uint8_t *)&payload, cmd_len);
2022-08-15 04:20:27 -05:00
return true;
2022-08-15 04:20:27 -05:00
}
uint32_t app_throughput_cmd_send_done(void *param1, uint32_t param2) {
if (throughputTestEnv.isThroughputTestOn &&
((app_ai_get_transport_type() == AI_TRANSPORT_BLE) ||
(WITHOUT_RSP == throughputTestConfig.responseModel))) {
app_throughput_test_transmission_handler(NULL, 0);
}
2022-08-15 04:20:27 -05:00
return 0;
2022-08-15 04:20:27 -05:00
}
uint32_t app_throughput_receive_cmd(void *param1, uint32_t param2) {
uint8_t *ptrbuf = NULL;
uint32_t data_length = 0;
APP_THROUGHPUT_CMD_PAYLOAD_T *pPayload = NULL;
TRACE(2, "%s data len %d", __func__, param2);
// DUMP8("0x%02x ", param1, param2);
data_length = param2;
while (data_length) {
ptrbuf = (uint8_t *)((uint32_t)param1 + param2 - data_length);
pPayload = (APP_THROUGHPUT_CMD_PAYLOAD_T *)ptrbuf;
data_length -= THROUGHPUT_CMD_PAYLOAD_HEADER_LEN;
if (data_length < pPayload->paramLen) {
TRACE(3, "%s error data_length %d paramLen %d", __func__, data_length,
pPayload->paramLen);
return 2;
}
TRACE(3, "%s data_length %d paramLen %d", __func__, data_length,
pPayload->paramLen);
data_length -= pPayload->paramLen;
// check parameter length
if (pPayload->paramLen > sizeof(pPayload->param)) {
TRACE(0, "SV COMMAND PARAM ERROR LENGTH");
return 4;
}
APP_THROUGHPUT_CMD_INSTANCE_T *pInstance =
find_throughput_instance_by_code(pPayload->cmdCode);
// execute the command handler
if (pInstance) {
pInstance->cmdHandler((APP_THROUGHPUT_CMD_CODE_E)(pPayload->cmdCode),
pPayload->param, pPayload->paramLen);
2022-08-15 04:20:27 -05:00
}
}
return 0;
2022-08-15 04:20:27 -05:00
}
#define APP_THROUGHPUT_PRE_CONFIG_PENDING_TIME_IN_MS 2000
2022-08-15 04:20:27 -05:00
static void app_throughput_pre_config_pending_timer_cb(void const *n);
osTimerDef(APP_THROUGHPUT_PRE_CONFIG_PENDING_TIMER,
app_throughput_pre_config_pending_timer_cb);
osTimerId app_throughput_pre_config_pending_timer_id = NULL;
2022-08-15 04:20:27 -05:00
static void app_throughput_test_data_xfer_lasting_timer_cb(void const *n);
osTimerDef(APP_THROUGHPUT_TEST_DATA_XFER_LASTING_TIMER,
app_throughput_test_data_xfer_lasting_timer_cb);
osTimerId app_throughput_test_data_xfer_lasting_timer_id = NULL;
2022-08-15 04:20:27 -05:00
static uint8_t app_throughput_datapattern[THROUGHPUT_DATA_MAX_SIZE];
static void app_throughput_test_data_xfer_lasting_timer_cb(void const *n) {
app_throughput_send_command(THROUGHPUT_OP_THROUGHPUT_TEST_DONE, NULL, 0);
2022-08-15 04:20:27 -05:00
app_stop_throughput_test();
2022-08-15 04:20:27 -05:00
}
static void app_throughput_pre_config_pending_timer_cb(void const *n) {
// inform the configuration
app_throughput_send_command(THROUGHPUT_OP_INFORM_THROUGHPUT_TEST_CONFIG,
(uint8_t *)&throughputTestConfig,
sizeof(throughputTestConfig));
if (UP_STREAM == throughputTestConfig.direction) {
app_throughput_test_transmission_handler(NULL, 0);
#ifndef SLAVE_ADV_BLE
osTimerStart(app_throughput_test_data_xfer_lasting_timer_id,
throughputTestConfig.lastTimeInSecond * 1000);
#endif
}
2022-08-15 04:20:27 -05:00
}
void app_throughput_test_init(void) {
memset(&throughputTestEnv, 0x00, sizeof(throughputTestEnv));
memset(&throughputTestConfig, 0x00, sizeof(throughputTestConfig));
2022-08-15 04:20:27 -05:00
app_throughput_pre_config_pending_timer_id = osTimerCreate(
osTimer(APP_THROUGHPUT_PRE_CONFIG_PENDING_TIMER), osTimerOnce, NULL);
2022-08-15 04:20:27 -05:00
app_throughput_test_data_xfer_lasting_timer_id = osTimerCreate(
osTimer(APP_THROUGHPUT_TEST_DATA_XFER_LASTING_TIMER), osTimerOnce, NULL);
2022-08-15 04:20:27 -05:00
}
static uint32_t app_throughput_test_transmission_handler(void *param1,
uint32_t param2) {
if (UP_STREAM == throughputTestConfig.direction) {
app_throughput_send_command(THROUGHPUT_OP_THROUGHPUT_TEST_DATA,
app_throughput_datapattern,
throughputTestConfig.dataPacketSize - 4);
}
2022-08-15 04:20:27 -05:00
return 0;
2022-08-15 04:20:27 -05:00
}
static void app_throughput_test_data_handler(APP_THROUGHPUT_CMD_CODE_E funcCode,
uint8_t *ptrParam,
uint32_t paramLen) {
if ((WITH_RSP == throughputTestConfig.responseModel) &&
(AI_TRANSPORT_SPP == app_ai_get_transport_type())) {
app_throughput_send_command(THROUGHPUT_OP_THROUGHPUT_TEST_DATA_ACK, NULL,
0);
}
2022-08-15 04:20:27 -05:00
}
static void
app_throughput_test_data_ack_handler(APP_THROUGHPUT_CMD_CODE_E funcCode,
uint8_t *ptrParam, uint32_t paramLen) {
if (throughputTestEnv.isThroughputTestOn &&
(WITH_RSP == throughputTestConfig.responseModel)) {
app_throughput_test_transmission_handler(NULL, 0);
}
2022-08-15 04:20:27 -05:00
}
static void
app_throughput_test_done_signal_handler(APP_THROUGHPUT_CMD_CODE_E funcCode,
uint8_t *ptrParam, uint32_t paramLen) {
app_stop_throughput_test();
2022-08-15 04:20:27 -05:00
}
void app_stop_throughput_test(void) {
throughputTestEnv.isThroughputTestOn = false;
osTimerStop(app_throughput_pre_config_pending_timer_id);
osTimerStop(app_throughput_test_data_xfer_lasting_timer_id);
2022-08-15 04:20:27 -05:00
}
static void
app_throughput_test_config_handler(APP_THROUGHPUT_CMD_CODE_E funcCode,
uint8_t *ptrParam, uint32_t paramLen) {
throughputTestConfig = *(THROUGHPUT_TEST_CONFIG_T *)ptrParam;
2022-08-15 04:20:27 -05:00
TRACE(4, "%s patter %d time %d response %d", __func__,
throughputTestConfig.dataPattern, throughputTestConfig.lastTimeInSecond,
throughputTestConfig.responseModel);
// generate the data pattern
switch (throughputTestConfig.dataPattern) {
case PATTERN_RANDOM: {
for (uint32_t index = 0; index < THROUGHPUT_DATA_MAX_SIZE; index++) {
app_throughput_datapattern[index] = (uint8_t)rand();
2022-08-15 04:20:27 -05:00
}
break;
}
case PATTERN_11110000: {
memset(app_throughput_datapattern, 0xF0, THROUGHPUT_DATA_MAX_SIZE);
break;
}
case PATTERN_10101010: {
memset(app_throughput_datapattern, 0xAA, THROUGHPUT_DATA_MAX_SIZE);
break;
}
case PATTERN_ALL_1: {
memset(app_throughput_datapattern, 0xFF, THROUGHPUT_DATA_MAX_SIZE);
break;
}
case PATTERN_ALL_0: {
memset(app_throughput_datapattern, 0, THROUGHPUT_DATA_MAX_SIZE);
break;
}
case PATTERN_00001111: {
memset(app_throughput_datapattern, 0x0F, THROUGHPUT_DATA_MAX_SIZE);
break;
}
case PATTERN_0101: {
memset(app_throughput_datapattern, 0x55, THROUGHPUT_DATA_MAX_SIZE);
break;
}
default:
throughputTestConfig.dataPattern = 0;
break;
}
throughputTestEnv.isThroughputTestOn = true;
throughputTestEnv.conidx = app_ai_if_get_ble_connection_index();
TRACE(2, "conidx 0x%x useSpecificConnParameter %d", throughputTestEnv.conidx,
throughputTestConfig.isToUseSpecificConnParameter);
// check whether need to use the new conn parameter
if (AI_TRANSPORT_BLE == app_ai_get_transport_type() &&
throughputTestConfig.isToUseSpecificConnParameter) {
if (throughputTestEnv.conidx != 0xFF) {
l2cap_update_param(throughputTestEnv.conidx,
throughputTestConfig.minConnIntervalInMs,
throughputTestConfig.maxConnIntervalInMs,
THROUGHPUT_BLE_CONNECTION_SUPERVISOR_TIMEOUT_IN_MS,
THROUGHPUT_BLE_CONNECTION_SLAVELATENCY);
2022-08-15 04:20:27 -05:00
}
osTimerStart(app_throughput_pre_config_pending_timer_id,
APP_THROUGHPUT_PRE_CONFIG_PENDING_TIME_IN_MS);
} else {
app_throughput_send_command(THROUGHPUT_OP_INFORM_THROUGHPUT_TEST_CONFIG,
(uint8_t *)&throughputTestConfig,
sizeof(throughputTestConfig));
2022-08-15 04:20:27 -05:00
if (UP_STREAM == throughputTestConfig.direction) {
app_throughput_test_transmission_handler(NULL, 0);
osTimerStart(app_throughput_test_data_xfer_lasting_timer_id,
throughputTestConfig.lastTimeInSecond * 1000);
}
}
}
2022-08-15 04:20:27 -05:00
APP_THROUGHPUT_CMD_INSTANCE_T
through_put_table[APP_THROUGHPUT_CMD_INSTANCE_NUMBER] = {
{THROUGHPUT_OP_INFORM_THROUGHPUT_TEST_CONFIG,
app_throughput_test_config_handler},
{THROUGHPUT_OP_THROUGHPUT_TEST_DATA, app_throughput_test_data_handler},
{THROUGHPUT_OP_THROUGHPUT_TEST_DATA_ACK,
app_throughput_test_data_ack_handler},
{THROUGHPUT_OP_THROUGHPUT_TEST_DONE,
app_throughput_test_done_signal_handler}};