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

本文详细介绍了蓝牙设备的配置过程,包括时钟与晶振准确度设置、蓝牙时间注册与管理、链接数目及角色配置、MTU协商值设定以及UUID设置等关键步骤。适合蓝牙设备开发者参考。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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;

 

### nRF52832 蓝牙协议栈实现及使用方法 #### 协议栈结构概述 蓝牙协议栈分为多个层次,每一层负责不同的功能。对于nRF52832而言,主要涉及的层次包括: - **控制器(Controller Layer)**:处理低级别的无线通信细节,如射频调制解调、基带控制等。 - **主机控制接口(HCI, Host Controller Interface)**:提供上层软件访问底层硬件的功能。 - **逻辑链路控制和适配协议(L2CAP, Logical Link Control and Adaptation Protocol)**:支持多路复用传输,并向上层应用屏蔽复杂的下层机制。 - **通用访问配置文件(GAP, Generic Access Profile)**:定义了设备的角色以及如何与其他设备交互的方式[^1]。 - **属性协议(ATT, Attribute Protocol)/ 安全管理器协议(SMP, Security Manager Protocol)**:前者用于读取写入特性值;后者则保障数据交换的安全性。 #### GAP 层角色与操作模式 在GAP层中,针对nRF52832可以设置四种基本角色——广播者(Broadcaster)、观察者(Observer)、外围设备(Peripheral) 和 中心设备(Central),这些角色决定了该节点在网络中的行为方式。此外还有几种重要的工作模式及其对应的过程来完成特定的任务,例如广播模式下的通告流程(Observation Procedure)。 #### 应用程序开发注意事项 当基于nRF52832进行应用程序编写时需要注意的是,Nordic Semiconductor已经预先集成了完整的Bluetooth Low Energy (BLE)堆栈到SoC内部闪存区域之中。这意味着开发者只需要关注于构建自己的应用程序逻辑部分即可,而无需关心整个协议栈的具体运作原理。不过,在某些情况下可能仍需调整一些参数或配置项以适应具体的项目需求[^3]。 #### 建立连接的关键要素 为了使两台装备有nRF52832模块之间的BLE链接能够顺利建立并维持稳定状态,则必须满足以下几个条件: - 双方就即将采用哪个物理信道达成共识; - 创建共享时间基准点使得两端能协调一致地安排收发动作; - 实现精确度较高的时钟同步以便准确预测对方的数据帧到达时刻[^5]。 ```c // 示例代码片段展示初始化外设角色的方法 void ble_peripheral_init(void){ ret_code_t err_code; // 初始化 SoftDevice 并启用 BLE 功能 err_code = sd_ble_enable(&ble_stack); APP_ERROR_CHECK(err_code); // 设置广告参数... } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值