0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

RTT_Zephyr_Polling BlueNRG2 SPI使用說明

冬至子 ? 來源:paradox ? 作者:paradox ? 2023-09-21 14:54 ? 次閱讀

RT-Thread平臺(tái)下,利用 BlueNRG2 藍(lán)牙芯片運(yùn)行 RTT_Zephyr_Polling 協(xié)議棧。使用 SPI 作為 HCI 傳輸方式。

這里開發(fā)和測(cè)試使用的都是 NUCLEO-L476RG 硬件平臺(tái),其他 MCU 硬件理論上只需按實(shí)際情況在 RTT 中修改引腳等設(shè)置。

硬件連接:NUCLEO-L476RG
使用 NUCLEO-L476RG 開發(fā)板配套的擴(kuò)展板連接 BlueNRG2,使用 SPI 作為 HCI 傳輸方式,運(yùn)行 RTT_Zephyr_Polling 藍(lán)牙協(xié)議棧。

如下圖連接好硬件即可:

1.jpg

搭建 RT-Thread Studio 環(huán)境
參考快速開始 完成 RT-Thread studio 環(huán)境的搭建。

創(chuàng)建項(xiàng)目工程
創(chuàng)建 STM32L476 ST-NUCLEO 示例工程

3.jpg

打開 SPI1 BUS(默認(rèn)使用SPI的bus1,可在Kconfig中修改),保存

1.jpg

這里RTT代碼因?yàn)榘姹締栴}(v5.0.1 202309),編譯會(huì)報(bào)錯(cuò)。RT_WEAK 字段在新版已經(jīng)被 rt_weak 替換。這里替換一下就可以正常編譯。

1.jpg

SPI引腳修改
當(dāng)前在RTT的BSP中 NUCLEO-L476RG 的默認(rèn)的SPI1_SCK為PA5。而在實(shí)際的硬件連接中時(shí),SPI1 連接的SCK引腳為PB3。將其修改為PB3,保存,generate code。這里可能需要將CubeMX多余的生成文件手動(dòng)刪除。

打開項(xiàng)目工程中的 cubemx_config.ioc,修改SPI1的引腳:

1.jpg

zephyr_polling 軟件包配置
在 RTT Studio 的軟件包中心添加zephyr_polling軟件包,配置項(xiàng)如下:

1.jpg

配置說明:
藍(lán)牙芯片選擇: bluenrg2
運(yùn)行平臺(tái)選擇: 使用 SPI 作為 HCI 通信接口
HCI 傳輸設(shè)置:選擇使用 rt-thread SPI。這里使用的硬件平臺(tái)是 STM32L476 ST-NUCLEO,且使用配套擴(kuò)展板連接,使用默認(rèn)配置即可。
如果換用其他硬件環(huán)境,但仍然使用 bluenrg2 藍(lán)牙芯片,需要根據(jù)實(shí)際情況修改:SPI BUS(SPI總線)、SPI INDEX(SPI設(shè)備號(hào))等。其中特別要注意,bluenrg2 的 SPI 通信除了MISO、MOSI、SCK三個(gè)基本信號(hào)線外,還需要一個(gè)由 MCU 控制的 CS_PIN 和一個(gè)由 bluenrg2 控制的 IRQ_PIN。這兩個(gè)引腳需要根據(jù)實(shí)際情況在這里設(shè)置。

這里先使用Beacon信標(biāo)例程進(jìn)行測(cè)試。保存設(shè)置,等待文件更新。

刷新 setting,可以看到項(xiàng)目資源目錄成功添加。

1.jpg

編譯項(xiàng)目代碼,下載。

Beacon例程運(yùn)行
上一步中已經(jīng)配置使用 Beacon 例程。

協(xié)議棧啟動(dòng)入口已導(dǎo)出為 cmd,輸入zephyr開啟一個(gè)線程運(yùn)行Beacn例程。

static int zephyr(void) {
static rt_thread_t tid = RT_NULL;
rt_kprintf("zephyr_polling_init rn");
tid = rt_thread_create("zephyr_polling_main",
zephyr_polling_main, RT_NULL,
4096,
5, 5);
if (tid != RT_NULL)
{
rt_thread_startup(tid);
}
return 0;
}
// INIT_APP_EXPORT(zephyr_polling_init);
MSH_CMD_EXPORT(zephyr, "zephyr_polling start");
運(yùn)行時(shí)串口打印如下:

initialize rti_board_start:0 done
initialize drv_pm_hw_init:0 done
initialize rt_hw_spi_init:0 done
| /

RT - Thread Operating System
/ | 5.0.1 build Sep 20 2023 21:08:57
2006 - 2022 Copyright by RT-Thread team
do components initialization.
initialize rti_board_end:0 done
initialize stm32l4_hw_lptim_init:0 done
initialize finsh_system_init:0 done
msh >zephyr
zephyr_polling_init
bt_init_hci_driver
SPI_init_process device_name: spi10, spi_name: spi1, rate: 1000000, databits: 8, LSB_MSB: 1, Master_Slave: 0, CPOL: 0, CPHA: 1
SPI_init_process cs_pin_num: 1, irq_pin_num: 0
hci_driver_open, SPI_config_finish
I: (bt_hci_core)hci_init():3230: work start.
msh >prepare_event_process, step: 1
prepare_event_process, step: 2
prepare_event_process, step: 3
prepare_event_process, step: 4
prepare_event_process, step: 5
I: (bt_hci_core)hci_init_end():3205: work end.
I: (bt_hci_core)bt_dev_show_info():3008: Identity: 02:80:e1:00:00:f5 (public)
I: (bt_hci_core)bt_dev_show_info():3042: HCI: version 5.2 (0x0b) revision 0x1222, manufacturer 0x0030
I: (bt_hci_core)bt_dev_show_info():3044: LMP: version 5.2 (0x0b) subver 0x0015
Bluetooth initialized
Beacon started, advertising as 02:80:e1:00:00:f5 (public)
其中

SPI_init_process device_name: spi10, spi_name: spi1, rate: >1000000, databits: 8, LSB_MSB: 1, Master_Slave: 0, CPOL: 0, CPHA: 1
SPI_init_process cs_pin_num: 1, irq_pin_num: 0
hci_driver_open, SPI_config_finish
是 HCI 使用的 SPI 配置參數(shù)。

prepare_event_process, step: 1
prepare_event_process, step: 2
prepare_event_process, step: 3
prepare_event_process, step: 4
prepare_event_process, step: 5
是芯片廠商設(shè)計(jì)的 bluenrg2 芯片啟動(dòng)流程(bluenrg2 不需要boot流程,但是有一系列的prepare流程)

手機(jī)端使用 nRF Connect 搜索藍(lán)牙信號(hào),即可成功觀察到藍(lán)牙設(shè)備地址為0280e10000:f5的beacon設(shè)備。

1.jpg

心率例程運(yùn)行
軟件包配置
軟件包配置如下,選擇 peripheralhr(外圍設(shè)備心率):

1.jpg

運(yùn)行
心率例程主要提供了兩個(gè) GATT 服務(wù):電池電量、心率數(shù)據(jù)。其中電池電量服務(wù)返回的是偽電量值,數(shù)值從 100% 隨時(shí)間遞減到 0% 循環(huán);心率服務(wù)返回的是隨機(jī)心率數(shù)據(jù)(單位bpm)。

輸入zephyr運(yùn)行Example

使用nRF Connect軟件連接藍(lán)牙:

1.jpg

獲取心率服務(wù)和電池電量服務(wù):

1.jpg

2.jpg

此時(shí)串口輸出:

initialize rti_board_start:0 done
initialize drv_pm_hw_init:0 done
initialize rt_hw_spi_init:0 done
| /

RT - Thread Operating System
/ | 5.0.1 build Sep 20 2023 22:16:27
2006 - 2022 Copyright by RT-Thread team
do components initialization.
initialize rti_board_end:0 done
initialize stm32l4_hw_lptim_init:0 done
initialize finsh_system_init:0 done
msh >zephyr
zephyr_polling_init
bt_init_hci_driver
SPI_init_process device_name: spi10, spi_name: spi1, rate: 1000000, databits: 8, LSB_MSB: 1, Master_Slave: 0, CPOL: 0, CPHA: 1
SPI_init_process cs_pin_num: 1, irq_pin_num: 0
hci_driver_open, SPI_config_finish
I: (bt_hci_core)hci_init():3230: work start.
msh >prepare_event_process, step: 1
prepare_event_process, step: 2
prepare_event_process, step: 3
prepare_event_process, step: 4
prepare_event_process, step: 5
I: (bt_hci_core)hci_init_end():3205: work end.
E: (bt_smp)smp_self_test():5695: smp_self_test start
I: (bt_hci_core)bt_dev_show_info():3008: Identity: 02:80:e1:00:00:f5 (public)
I: (bt_hci_core)bt_dev_show_info():3042: HCI: version 5.2 (0x0b) revision 0x1222, manufacturer 0x0030
I: (bt_hci_core)bt_dev_show_info():3044: LMP: version 5.2 (0x0b) subver 0x0015
Bluetooth initialized
Advertising successfully started
Connected
BAS Notifications enabled
HRS notifications enabled

數(shù)據(jù)吞吐例程運(yùn)行與測(cè)試
軟件包配置

1.jpg

運(yùn)行
數(shù)據(jù)吞吐例程內(nèi)部邏輯是將接收到的數(shù)據(jù)轉(zhuǎn)發(fā)回中心設(shè)備。主要提供了兩個(gè) GATT 服務(wù):write 和 notify。前者用于接收中心設(shè)備發(fā)來的數(shù)據(jù),后者用于向連接的中心設(shè)備發(fā)送數(shù)據(jù)。

輸入zephyr運(yùn)行Example。

手機(jī)端使用 BLE調(diào)試寶(類似的BLE APP應(yīng)該都行)連接設(shè)備,開啟notify服務(wù):

1.jpg

連續(xù)發(fā)送數(shù)據(jù):

1.jpg

收發(fā)數(shù)據(jù)沒有丟包。

串口打印如下:

initialize rti_board_start:0 done
initialize drv_pm_hw_init:0 done
initialize rt_hw_spi_init:0 done
| /

RT - Thread Operating System
/ | 5.0.1 build Sep 20 2023 22:39:47
2006 - 2022 Copyright by RT-Thread team
do components initialization.
initialize rti_board_end:0 done
initialize stm32l4_hw_lptim_init:0 done
initialize finsh_system_init:0 done
msh >zephyr
zephyr_polling_init
bt_init_hci_driver
SPI_init_process device_name: spi10, spi_name: spi1, rate: 1000000, databits: 8, LSB_MSB: 1, Master_Slave: 0, CPOL: 0, CPHA: 1
SPI_init_process cs_pin_num: 1, irq_pin_num: 0
hci_driver_open, SPI_config_finish
I: (bt_hci_core)hci_init():3230: work start.
msh >prepare_event_process, step: 1
prepare_event_process, step: 2
prepare_event_process, step: 3
prepare_event_process, step: 4
prepare_event_process, step: 5
I: (bt_hci_core)hci_init_end():3205: work end.
E: (bt_smp)smp_self_test():5695: smp_self_test start
I: (bt_hci_core)bt_dev_show_info():3008: Identity: 02:80:e1:00:00:f5 (public)
I: (bt_hci_core)bt_dev_show_info():3042: HCI: version 5.2 (0x0b) revision 0x1222, manufacturer 0x0030
I: (bt_hci_core)bt_dev_show_info():3044: LMP: version 5.2 (0x0b) subver 0x0015
Bluetooth initialized
throughput_svc_init()
Advertising successfully started
I: (bt_hci_core)bt_sleep_prepare_work():4040: start
I: (bt_hci_core)bt_sleep_prepare_work():4046: end
I: (bt_hci_core)bt_sleep_wakeup_work_start():4058: start
I: (bt_hci_core)bt_sleep_wakeup_work_start():4061: end
I: (bt_hci_core)bt_sleep_wakeup_work_end():4072: start
I: (bt_hci_core)bt_sleep_wakeup_work_end():4074: end
Connected

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 藍(lán)牙芯片
    +關(guān)注

    關(guān)注

    17

    文章

    371

    瀏覽量

    45945
  • SPI接口
    +關(guān)注

    關(guān)注

    0

    文章

    258

    瀏覽量

    34317
  • RT-Thread
    +關(guān)注

    關(guān)注

    31

    文章

    1261

    瀏覽量

    39837
  • MCU控制器
    +關(guān)注

    關(guān)注

    0

    文章

    27

    瀏覽量

    6867
  • STM32L476
    +關(guān)注

    關(guān)注

    0

    文章

    7

    瀏覽量

    3763
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    RTT平臺(tái)zephyr_polling軟件包SPI Bluenrg2芯片宕機(jī)問題與修復(fù)

    項(xiàng)目的代碼測(cè)試完成之后,準(zhǔn)備收尾時(shí),出現(xiàn)了問題。清除掉開發(fā)過程中用來調(diào)試的print打印之后,zephyr_polling 的 HCI 突然不能正常工作了,之前測(cè)試可用的 zephyr_polling 中的各個(gè)例程都不再能運(yùn)行。
    的頭像 發(fā)表于 09-25 17:08 ?1047次閱讀
    <b class='flag-5'>RTT</b>平臺(tái)<b class='flag-5'>zephyr_polling</b>軟件包<b class='flag-5'>SPI</b> <b class='flag-5'>Bluenrg2</b>芯片宕機(jī)問題與修復(fù)

    RTT zephyr_polling軟件包 Bluenrg2藍(lán)牙芯片啟動(dòng)流程

    在用標(biāo)準(zhǔn)的 HCI 指令控制設(shè)備進(jìn)行藍(lán)牙操作之前,需要提前通過 VS Command 對(duì)設(shè)備進(jìn)行配置,只有正確配置好的設(shè)備才能正常使用。
    的頭像 發(fā)表于 09-27 11:19 ?1272次閱讀
    <b class='flag-5'>RTT</b> <b class='flag-5'>zephyr_polling</b>軟件包 <b class='flag-5'>Bluenrg2</b>藍(lán)牙芯片啟動(dòng)流程

    如何用Ubuntu qemu跑zephyr_polling的藍(lán)牙?

    進(jìn)入 RT-Thread online packages → IoT - internet of things 目錄即可看到 zephyr_polling軟件包,勾選軟件包。
    的頭像 發(fā)表于 09-28 11:24 ?1840次閱讀
    如何用Ubuntu qemu跑<b class='flag-5'>zephyr_polling</b>的藍(lán)牙?

    Xilinx FPGA2 pro使用說明

    從光盤上拷下來的,Xilinx FPGA2 pro使用說明,想要的拿去吧
    發(fā)表于 10-24 10:14

    RTThread Studio的芯片支持包使用說明

    介紹本倉(cāng)庫(kù)為RTThread Studio的芯片支持包,目前暫時(shí)支持52832及52840的rtt完整版下載地址導(dǎo)入教程使用說明創(chuàng)建RTT工程選擇芯片及配置串口引腳(目前只支持選擇0端口)后,完成項(xiàng)目創(chuàng)建更改工程配置如果還需要藍(lán)
    發(fā)表于 08-04 10:48

    怎樣使用SDK中的Beacon示例對(duì)BLUENRG2進(jìn)行重新編程呢?

    我希望使用 BLUENRG-M2 模塊構(gòu)建一個(gè)帶有 BLUENRG2 的項(xiàng)目。我購(gòu)買了一塊 X-NUCLEO-BNRG2A1 板開始使用,并將該板上的 SWDIO、SWDCLK、NRESET、VDD
    發(fā)表于 01-03 10:00

    BlueNRG-2最大SPI時(shí)鐘的速率限制有多嚴(yán)格?

    我目前正在使用 X-NUCLEO-BNRG2A1 來試驗(yàn) BlueNRG-2。我最初將 SPI 速率設(shè)置為 1.25 Mbit/s,但后來在 BlueNRG-2 文檔中注意到最大
    發(fā)表于 01-06 06:25

    硬件重置時(shí)BlueNRG-MS SPI事務(wù)意外響應(yīng)怎么解決?

    -MS (SPI) 測(cè)試程序。我正在使用 STEVAL-IDB005V1D 板(帶有 BLUENRG-MS 芯片)和 NUCLEO-F446RE 板來讀取 SPI 信號(hào)。這是測(cè)試程序(AN4494 第 5
    發(fā)表于 01-06 07:27

    如何使用RT685的DSP搭配Zephyr OS?

    “evkmimxrt685_dsp_mu_polling”完成了此操作,它運(yùn)行良好。 現(xiàn)在我想對(duì) Zephyr OS 做同樣的事情。我用這個(gè)平臺(tái)制作了幾個(gè)應(yīng)用程序,這適用于 ARM 部分。 我沒有
    發(fā)表于 05-18 08:04

    ESP8266_SPI模塊使用說明_Version 0.1

    ESP8266__SPI_Module_User Guide,SPI 模塊使用說明
    發(fā)表于 12-30 14:40 ?281次下載

    RT-Thread (2RTT SPI設(shè)備驅(qū)動(dòng)流程 || LWIP + ENC28J60

    系列文章目錄RT-Thread (1) 添加外部?jī)?nèi)存到內(nèi)存管理RT-Thread (2RTT SPI設(shè)備驅(qū)動(dòng)流程 || LWIP + ENC28J60目錄0 概述0.0 參考資料0.1 硬件資源
    發(fā)表于 11-19 14:21 ?15次下載
    RT-Thread (<b class='flag-5'>2</b>) <b class='flag-5'>RTT</b> <b class='flag-5'>SPI</b>設(shè)備驅(qū)動(dòng)流程 || LWIP + ENC28J60

    RTT zephyr_polling SPI Bluenrg2數(shù)據(jù)傳輸測(cè)試

    RTT 那邊的 Kconfig 配置完成,項(xiàng)目的基本開發(fā)內(nèi)容就完成了。然后再對(duì)協(xié)議棧在 Bluenrg2 芯片上采用 SPI 作為 HCI 的數(shù)據(jù)傳輸進(jìn)行測(cè)試。
    的頭像 發(fā)表于 09-25 16:25 ?832次閱讀
    <b class='flag-5'>RTT</b> <b class='flag-5'>zephyr_polling</b> <b class='flag-5'>SPI</b> <b class='flag-5'>Bluenrg2</b>數(shù)據(jù)傳輸測(cè)試

    RT-Thread平臺(tái) zephyr_polling軟件包 Bluenrg2 藍(lán)牙芯片啟動(dòng)流程

    地址:RTT_PACKAGE_zephyr_polling 前面已經(jīng)完成了 SPI 接口的實(shí)現(xiàn),要讓 zephyr_pollingBluenrg2 上運(yùn)行起來,下一步是實(shí)現(xiàn)其特殊
    的頭像 發(fā)表于 09-27 18:40 ?818次閱讀
    RT-Thread平臺(tái) <b class='flag-5'>zephyr_polling</b>軟件包 <b class='flag-5'>Bluenrg2</b> 藍(lán)牙芯片啟動(dòng)流程

    實(shí)戰(zhàn)經(jīng)驗(yàn) | BlueNRG-X 原理圖參數(shù)說明(附資料下載端口)

    關(guān)鍵詞:BlueNRG-1, BlueNRG-2, BlueNRG-LP/LPS 目錄預(yù)覽 1、前言 2、BlueNRG-1/-
    的頭像 發(fā)表于 10-18 19:15 ?666次閱讀

    RTT平臺(tái)zephyr_polling軟件包SPI Bluenrg2丟包問題排查

    在對(duì)協(xié)議棧在 Bluenrg2 芯片上采用 SPI 作為 HCI 的數(shù)據(jù)傳輸進(jìn)行測(cè)試的時(shí)候,發(fā)現(xiàn)存在丟包問題。
    的頭像 發(fā)表于 10-23 15:41 ?538次閱讀
    <b class='flag-5'>RTT</b>平臺(tái)<b class='flag-5'>zephyr_polling</b>軟件包<b class='flag-5'>SPI</b> <b class='flag-5'>Bluenrg2</b>丟包問題排查