NRF52832----蓝牙协议栈初始化配置

1、配置协议栈时钟与晶振准确度

//按照以上路径找到最后一个宏定义“NRF_SDH_CLOCK_LF_SRC”,修改这里即可更改时钟源
//外部晶振较省电,因为内部RC校准时必须运行32MHz高速时钟,比外部多9us电流
//协议栈使用RTC0作为时钟
ble_stack_init -> nrf_sdh_enable_request -> .source = NRF_SDH_CLOCK_LF_SRC


//以下结构体成员用来修改晶振的准确度,根据自己晶振的规格书选择
.accuracy  = NRF_SDH_CLOCK_LF_ACCURACY

 

 

2、蓝牙时间的注册与管理

//注册蓝牙事件,回调函数为ble_evt_handler
NRF_SDH_BLE_OBSERVER(m_ble_observer, APP_BLE_OBSERVER_PRIO, ble_evt_handler, NULL);

//主要是连接,断开事件,超时事件等
static void ble_evt_handler(ble_evt_t const * p_ble_evt, void * p_context)
{
    ret_code_t err_code;

    switch (p_ble_evt->header.evt_id)
    {
        case BLE_GAP_EVT_CONNECTED:
            NRF_LOG_INFO("Connected");  //打印GAP连接信息
            bsp_board_led_on(CONNECTED_LED); //LED2亮
            bsp_board_led_off(ADVERTISING_LED); //LED1灭
            m_conn_handle = p_ble_evt->evt.gap_evt.conn_handle;
            err_code = nrf_ble_qwr_conn_handle_assign(&m_qwr, m_conn_handle);
            APP_ERROR_CHECK(err_code);
            err_code = app_button_enable();
            APP_ERROR_CHECK(err_code);
            break;

        case BLE_GAP_EVT_DISCONNECTED:
            NRF_LOG_INFO("Disconnected");
            bsp_board_led_off(CONNECTED_LED);
            m_conn_handle = BLE_CONN_HANDLE_INVALID;
            err_code = app_button_disable();
            APP_ERROR_CHECK(err_code);
            advertising_start();
            break;

        case BLE_GAP_EVT_SEC_PARAMS_REQUEST:
            // Pairing not supported
            err_code = sd_ble_gap_sec_params_reply(m_conn_handle,
                                                   BLE_GAP_SEC_STATUS_PAIRING_NOT_SUPP,
                                                   NULL,
                                                   NULL);
            APP_ERROR_CHECK(err_code);
            break;

        case BLE_GAP_EVT_PHY_UPDATE_REQUEST:
        {
            NRF_LOG_DEBUG("PHY update request.");
            ble_gap_phys_t const phys =
            {
                .rx_phys = BLE_GAP_PHY_AUTO,
                .tx_phys = BLE_GAP_PHY_AUTO,
            };
            err_code = sd_ble_gap_phy_update(p_ble_evt->evt.gap_evt.conn_handle, &phys);
            APP_ERROR_CHECK(err_code);
        } break;

        case BLE_GATTS_EVT_SYS_ATTR_MISSING:
            // No system attributes have been stored.
            err_code = sd_ble_gatts_sys_attr_set(m_conn_handle, NULL, 0, 0);
            APP_ERROR_CHECK(err_code);
            break;

        case BLE_GATTC_EVT_TIMEOUT:
            // Disconnect on GATT Client timeout event.
            NRF_LOG_DEBUG("GATT Client Timeout.");
            err_code = sd_ble_gap_disconnect(p_ble_evt->evt.gattc_evt.conn_handle,
                                             BLE_HCI_REMOTE_USER_TERMINATED_CONNECTION);
            APP_ERROR_CHECK(err_code);
            break;

        case BLE_GATTS_EVT_TIMEOUT:
            // Disconnect on GATT Server timeout event.
            NRF_LOG_DEBUG("GATT Server Timeout.");
            err_code = sd_ble_gap_disconnect(p_ble_evt->evt.gatts_evt.conn_handle,
                                             BLE_HCI_REMOTE_USER_TERMINATED_CONNECTION);
            APP_ERROR_CHECK(err_code);
            break;

        default:
            // No implementation needed.
            break;
    }
}

 

3、配置链接数目以及角色

//配置总的链接数目,等于程序中设置的从机和主机的数目和
ble_stack_init -> nrf_sdh_ble_default_cfg_set -> ble_cfg.conn_cfg.params.gap_conn_cfg.conn_count   = NRF_SDH_BLE_TOTAL_LINK_COUNT;

//配置GAP事件长度,蓝牙底层发送数据包时给的处理时间
ble_cfg.conn_cfg.params.gap_conn_cfg.event_length = NRF_SDH_BLE_GAP_EVENT_LENGTH;

//作为从机角色,可被连接数目
ble_cfg.gap_cfg.role_count_cfg.periph_role_count  = NRF_SDH_BLE_PERIPHERAL_LINK_COUNT;

//作为主机角色数目,可被连接数目
ble_cfg.gap_cfg.role_count_cfg.central_role_count = NRF_SDH_BLE_CENTRAL_LINK_COUNT;

 

4、配置MTU协商值

//值越大,一次通讯可传输的数据越多
//配置这个宏即可,正常为23,蓝牙4为23。
NRF_SDH_BLE_GATT_MAX_MTU_SIZE

5、设置UUID

//这个配置的是私人任务数
ble_cfg.common_cfg.vs_uuid_cfg.vs_uuid_count = NRF_SDH_BLE_VS_UUID_COUNT; 

7、配置GATT属性表的大小

ble_cfg.gatts_cfg.attr_tab_size.attr_tab_size = NRF_SDH_BLE_GATTS_ATTR_TAB_SIZE;

 

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
nrf52840是一款低功耗蓝牙芯片,它具有强大的处理能力和丰富的外设接口,广泛应用于物联网和无线通信领域。协议栈初始化是在使用nrf52840芯片进行蓝牙通信时的一个重要步骤。 在nrf52840上进行协议栈初始化时,需要进行以下几个步骤: 1. 配置引脚:首先需要配置芯片的引脚,包括蓝牙通信所需的引脚和外设接口的引脚。可以使用芯片厂商提供的开发工具或者SDK来进行引脚配置。 2. 初始化时钟:接下来需要初始化芯片的时钟,确保系统时钟正常工作。可以使用芯片厂商提供的时钟初始化函数来完成。 3. 配置协议栈参数:在进行协议栈初始化之前,需要配置一些协议栈参数,例如蓝牙设备名称、设备地址等。这些参数可以通过调用相应的API函数来设置。 4. 初始化协议栈:最后一步是初始化协议栈本身。可以使用芯片厂商提供的协议栈初始化函数来完成。在初始化过程中,协议栈会进行一系列的初始化操作,包括分配内存、注册回调函数等。 如果nrf52840协议栈初始化不过,可能是由于以下几个原因: 1. 引脚配置错误:检查引脚配置是否正确,确保蓝牙通信所需的引脚和外设接口的引脚配置正确。 2. 时钟初始化错误:检查时钟初始化是否正确,确保系统时钟正常工作。 3. 协议栈参数配置错误:检查协议栈参数的配置是否正确,例如蓝牙设备名称、设备地址等。 4. 协议栈初始化函数调用错误:检查协议栈初始化函数的调用是否正确,确保使用了正确的函数和参数。 如果以上步骤都没有问题,还是无法通过协议栈初始化,可以参考芯片厂商提供的文档或者开发社区中的相关讨论,寻求帮助解决问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值