Nordic nRF52840实战学习--透传模块速率优化

方案一:使用定时器定时发送数据

1.1 定义一个定时器ID:

APP_TIMER_DEF(m_test_speed_tmr);

1.2 定时器初始化:

  ret_code_t err_code;
  err_code = app_timer_create(&m_test_speed_tmr,
                              APP_TIMER_MODE_REPEATED,
                              speed_timer_handler);

1.3 定义定时器回调处理函数:

static void speed_timer_handler(void * p_context)
{
  uint32_t err_code;
  length = m_ble_nus_max_data_len;
  err_code = ble_nus_data_send(&m_nus, m_data_array, &length, m_conn_handle);
  if ((err_code != NRF_ERROR_INVALID_STATE) &&
      (err_code != NRF_ERROR_RESOURCES) &&
      (err_code != NRF_ERROR_NOT_FOUND))
  {
      APP_ERROR_CHECK(err_code);
  }
  if(err_code == NRF_SUCCESS)
  {
     m_cnt_7ms++;
     total_send_data_cnt += length;
     m_data_array[0]++;
     m_data_array[length-1]++;
     NRF_LOG_INFO("time: %d ms == bytes send: %d Bytes == avg speed: %d B/s",m_cnt_7ms*7,total_send_data_cnt,(total_send_data_cnt * 1000)/(m_cnt_7ms*7));
  }
}

1.4 定义定时器开始的条件(这里是当APP连上蓝牙并且使能notification后开始)

static void nus_data_handler(ble_nus_evt_t * p_evt)
{

    if (p_evt->type == BLE_NUS_EVT_RX_DATA)
    {
        uint32_t err_code;

        NRF_LOG_DEBUG("Received data from BLE NUS. Writing data on UART.");
        NRF_LOG_HEXDUMP_DEBUG(p_evt->params.rx_data.p_data, p_evt->params.rx_data.length);

        for (uint32_t i = 0; i < p_evt->params.rx_data.length; i++)
        {
            do
            {
                err_code = app_uart_put(p_evt->params.rx_data.p_data[i]);
                if ((err_code != NRF_SUCCESS) && (err_code != NRF_ERROR_BUSY))
                {
                    NRF_LOG_ERROR("Failed receiving NUS message. Error 0x%x. ", err_code);
                    APP_ERROR_CHECK(err_code);
                }
            } while (err_code == NRF_ERROR_BUSY);
        }
        if (p_evt->params.rx_data.p_data[p_evt->params.rx_data.length - 1] == '\r')
        {
            while (app_uart_put('\n') == NRF_ERROR_BUSY);
        }
    }

    if(p_evt->type == BLE_NUS_EVT_TX_RDY)//Service is ready to accept new data to be transmitted.
    {

    }

    if(p_evt->type == BLE_NUS_EVT_COMM_STARTED)//Notification has been enabled
    {
      app_timer_start(m_test_speed_tmr, APP_TIMER_TICKS(7), NULL);
    }

}

1.5 测试方案的效果(效果一般,仅34KB/s左右)

方案二:在每个连接间隔时间连续发送多个数据包

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值