精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

無線MCU調試技巧匯總

jf_pJlTbmA9 ? 來源:恩智浦MCU加油站 ? 作者:恩智浦MCU加油站 ? 2023-10-17 14:56 ? 次閱讀

對于初次接觸無線MCU產品的人來說,拿到恩智浦的SDK后肯定需要一段時間適應,其實無線MCU也是MCU,只是在MCU的基礎上增加了一個稍顯復雜的射頻單元,另外圍繞這個射頻單元增加了一些輔助組件,比如framework,FreeRtos等,當然因為射頻部分具有最高的優先級,所以用戶的應用必須附屬在無線系統之上。

恩智浦旗下的無線MCU采用了與普通MCU相同的SDK架構,對于芯片間的切換其實是很方便的。

下面是我總結的一些開發無線MCU的經驗,希望能幫到剛開始使用NXP無線MCU的同學們。

本文由如下幾部分組成:

開發環境

如何開始

低功耗模式下的代碼調試

空中包時序分析

Controller enhanced notifications

Timer、Event及其它資源分配

發射功率調節

Panic分析

本文所有實例基于KW38芯片講解,但對于同一系列的其它KW3x芯片同樣適用,對于使用同一SDK架構的其它無線芯片(如QN9080,QN9090)大多數適用。

開發環境

SDK版本:SDK_2_6_13_FRDM-KW38

SDK下載地址:https://mcuxpresso.nxp.com

開發板:FRDM-KW38

IDE:IAR EmbeddedWorkbench for Arm version 8.50

演示代碼:https://github.com/N40E116/SDK_2_6_13_FRDM-KW38.git

如何開始

如果是第一次使用NXP的無線MCU,請先瀏覽SDK中的如下兩個文件:

Bluetooth Low Energy Quick Start Guide.pdf

Bluetooth Low Energy Demo ApplicationsUser's Guide.pdf

本文中的所有演示操作基于項目temp_sens/freertos,之所以選擇這個工程是因為它包含了低功耗和串口輸出等功能,方便演示。

SDK中所有項目都包含bm和freertos兩個版本,其中bm是不含RTOS的版本,FreeRtos是集成了RTOS的版本。

注意SDK中并非所有項目默認都是使能低功耗的,只有如下工程包含低功耗處理:

adv_ext_central /adv_ext_peripheral

beacon

ble_fscibb

hrs

temp_coll / temp_sens

建議在程序中增加打印復位源的功能,方便異常時的檢測,實例代碼如下:

void BleApp_Init(void)
{
…
    (void)Serial_Print(gAppSerMgrIf, "rnReset source:", gNoBlock_d);
    Serial_PrintDec(gAppSerMgrIf, PWR_GetSystemResetStatus());
    (void)Serial_Print(gAppSerMgrIf, "rn", gNoBlock_d);
}

如果你已經足夠熟悉SDK的框架,現在準備開始開發自己的產品,強烈建議你只修改項目所在工程目錄下的文件,因為其它文件是所有項目公用的,修改后可能導致其它項目的編譯或運行問題,另外這樣做的好處是,后續如果需要升級SDK,只需對比這些文件,進行移植即可,可大大節省升級時間。

如下是演示項目的工程目錄結構,可以在這里修改或增加文件:

SDK_2_6_13_FRDM-KW38boardsfrdmkw38wireless_examplesbluetoothtemp_sens

wKgZomUD71WAOgdOAANAhBE38-8018.png

低功耗模式下的代碼調試

如果直接將未經修改的temp_sens工程下載KW38中并開啟調試,很快你就會收到如下錯誤提示,這是因為KW38進入了低功耗模式, SWD引腳失去調試功能,J-Link和KW38失去了通訊,所以調試器斷開了。

wKgZomUD71aAVkw8AAB7A60zDAA896.png

要在低功耗的模式下調試代碼,我們需要定時喚醒KW38,讓debugger認為被調試芯片是一直在線的,我們可以讓KW38一直處于廣播或連接狀態,這樣KW38為了處理藍牙事件會定時喚醒,從而保持住SWD連接。

另外KW38進入的低功耗模式也是有選擇的,需要進入Low Power mode 1。如下是對應的代碼修改:

#define gAppStartAfterReset_d           1
#define gAppDeepSleepMode_c             1

static void AdvertisingTimerCallback(void* pParam)
{
    /* Stop advertising */
//    if (mAdvState.advOn)
//    {
//        (void)Gap_StopAdvertising();
//    }
}

BleApp_ConnectionCallback() -> case gConnEvtDisconnected_c:
#if defined(cPWR_UsePowerDownMode)    (cPWR_UsePowerDownMode)
            /* UI */
            Led1Off();
            /* Go to sleep */
            SleepTimeoutSequence();
            /* restart advertising*/
            BleApp_Start();
#else

如果需要上電后或復位后馬上開啟廣播,可使能如下宏定義:

#define gAppStartAfterReset_d     1

對于各功耗模式的介紹可參考源碼文件PWR_Configuration.h。

為了快速掃描連接到設備,可以修改一下KW38的廣播間隔,實例代碼如下:

gapAdvertisingParameters_t gAdvParams = {
    /* minInterval */         gGapAdvertisingIntervalRangeMinimum_c, //0x12C0,
    /* maxInterval */         gGapAdvertisingIntervalRangeMinimum_c, //0x1900,
…
}

如果向已經下載過使能低功耗程序的開發板再次下載代碼,有時會無法識別到芯片,此時需要按住開發板的SW3鍵以喚醒KW38,再點擊下載按鈕。

如果你現在沒有調試低功耗功能,為方便開發調試,建議先禁用低功耗模式,只需修改如下宏定義:

#define cPWR_UsePowerDownMode    0

如果你的產品最終選擇的功耗模式是需要MCU進入VLLSx模式的,比如low power mode:5/8/9,那么每次休眠喚醒后,需要重新初始化外設,因為從這些模式喚醒走的是reset流程,不過進入休眠后IO引腳的輸出電平狀態是可以保持的。

空中包時序分析

使用Ellisys的Bluetooth Tracker抓包工具,結合它的邏輯分析儀功能,我們可以抓取到藍牙空中包和IO的時序關系,以下是我們使用該功能分析KW38功耗狀態的一個實例。進入低功耗模式前拉低LED1引腳,退出低功耗模式后置高LED1。

#define gLEDSupported_d             1

#include "LED.h"
void BOARD_EnterLowPowerCb(void)
{
    Led1Off();
…
}

void BOARD_ExitLowPowerCb(void)
{
    Led1On(); 
…
}

抓取到的空中數據和LED1引腳數據如下:

wKgaomUD71iAdLOrAABq9zj_9c0521.png

聚焦到一個連接事件,我們看到KW38在空中包到來之前大約3ms喚醒了MCU,在處理完藍牙事件后大約304us進入低功耗模式。

wKgaomUD71mAfQsgAABP7syG5PU427.png

Controller enhanced notifications

該特性可以產生額外的如下圖所示藍牙事件,但是默認只有wireless_uart使能了該功能,如果需要這些額外的event,請參考工程wireless_uart。

wKgaomUD71uAdInQAAIee00qhlE341.png

Timer、Event及其它資源分配

強烈建議用戶仔細瀏覽一遍app_preinclude.h文件,該文件中包含了大多數項目配置信息,如果用戶有增加的配置項的話,也建議放到這個文件中統一管理。

如用戶需要自己創建Timer或Event的話,則如下配置參數需要對應的增加。

/* Defines number of OS events used */
#define osNumberOfEvents        5

/* Defines number of timers needed by the application */
#define gTmrApplicationTimers_c   (4 + gRepeatedAttemptsTimers_d + gAppAllowDeviceToSleepTimers_d)

app_config.c文件中包含了藍牙的配置信息,如廣播內容,安全設置,如有需要可修改該文件。

gatt_db.h文件定義了藍牙的service,可以參考該文件增加或修改用戶自定義的service。

發射功率調節

KW36系列通過如下宏定義,配置藍牙的發射功率,但是該值對應的實際發射功率是如何計算的呢?

#define mAdvertisingDefaultTxPower_c  20
#define mConnectionDefaultTxPower_c    20

#define mDefaultTxPowerUsePaBump_c    0

在KW36的datasheet里有如下表格,有兩種方法計算實際發射功率:

第一種,設置值直接對應下面表格里的行數(從行0開始),如設置TxPower_c為3,則發射功率對應的PA_POWER[5:0]= 6,對應的25℃發射功率為-15.6。

第二種,設置值為0時,PA_POWER[5:0]=1, 設置值為其它值時,PA_POWER[5:0]為二倍的設置值,然后通過下表查詢對應的發射功率,如設置值為5,則PA_POWER[5:0] = 5*2=10,查詢下表對應的25℃發射功率為-11.2。

wKgZomUD71yAL7ZuAAFAH5lGrJQ384.png

上表對應的是未使能最大+5dBm輸出時的配置,如果使能了+5dBm輸出,請參考如下表格,修改宏定義mDefaultTxPowerUsePaBump_c為1,可使能+5dBm輸出。

wKgZomUD712AGa-RAAFJbLlnNrU950.png

對于KW38系列,使用如下API配置發射功率,因為輸入參數即為發射功率值,所以不再需要任何轉換。
bleResult_t Controller_SetTxPowerLevelDbm(int8_t level_dbm, txChannelType_t channel);

Panic分析

這里的演示會使用到Segger的J-Link Commander,所以如果你的開發板的debugger固件呈現的不是J-Link的話,你需要按照如下鏈接里的說明更新debugger為Segger Jlink。或者使用一個外部的J-Link或J-Trace作為debugger。

OpenSDASerial and Debug Adapter | NXP Semiconductors

Panic是Framework下的一個十分有用的調試工具,在開發調試階段用于捕捉各種錯誤,SDK中默認已經在很多異常處添加了Panic處理,但是該功能默認是關閉的,需要定義如下宏打開:

#define gUsePanic_c  1

Debugger在線調試分析

如果是連著Debugger的在線調試,我們只需暫停代碼即可看到panic的位置,通過panic_data中保存的數據,我們能進一步定位到出問題時的更多信息,如下是我偽造的一個panic場景。

void BleApp_Start(void)
{
…
    panic(0,(uint32_t)BleApp_Start,1,2);
}

運行代碼,程序卡死在panic里,暫停程序,并查看相關信息如下:

wKgaomUD71-AVpAXAANoh6XroX0964.png

將location里的地址0x234b9輸入到匯編窗口的搜索欄,可以看到出問題的函數是BleApp_Start(),當然這個也可以通過Call Stack進行查看。另外我們可以看到出問題時的一些其它參數extra1和extra2。

wKgZomUD72CAQn28AAOOCn1ya1M621.png

離線分析

很多場景下,產品是在沒有連接debugger的情況下出現了異常,此時我們就需要Segger的J-Link Commander工具了,注意調試使用的debugger必須是J-Link或J-Trace等Segger公司的產品。

剛才相同的代碼,下載到開發板后,斷開debugger讓程序全速運行,此時程序應該也運行到了panic的位置,但是我們如何查看呢?

打開J-Link Commander,并連接到KW38芯片,輸入命令‘h’,此時可看到程序PC指針為0x19160。

wKgZomUD72KAae8JAALJhM7mRzk855.png

通過addr2line工具我們可以定位到出問題的代碼文件為Panic.c,行數為65,addr2line的安裝十分簡單,大家可自行搜索下載安裝。

wKgaomUD72SADhCNAAFytyp_8w4576.png

對于出問題時的其它數據,我們可以通過變量panic_data查看,通過.map文件定位到panic_data的地址為0x2000421c。

wKgZomUD72WAVVCNAABNDsoZAVs141.png

結構體panic_data的定義如下:

typedef struct
{
    panicId_t id;
    uint32_t location;
    uint32_t extra1;
    uint32_t extra2;
    uint32_t linkRegister;
    uint32_t cpsr_contents;   /* may not be used initially */
    uint8_t stack_dump[4];    /* initially just contain the contents of the LR */
} panicData_t;

使用J-Link Commander的‘mem32’命令可以讀取到如下圖所示的panic_data數據,通過這些數據,查找出出問題的函數地址為0x234b9, extra1為1,extra2為2。

wKgZomUD72eAT1L6AAChH8rmlPo907.png

通過addr2line命令查詢到出問題的函數位于temperature_sensor.c文件的179行,即BleApp_Start()函數,再結合當時保存的extra1和extra2參數,我們大概就能分析出問題的原因了。

wKgaomUD72mAB8QCAAD3GO1o0-s195.png
wKgaomUD72qAXwVsAABQhaU3m6U930.png

該方法用于panic后的代碼追蹤,當然也適用于程序跳入死循環、Hardfault及其它的一些debugger離線后的異常分析。

以上是我在使用無線MCU時總結的一點經驗,希望能幫到剛剛入門無線產品的同學們。

來源:恩智浦MCU加油站
免責聲明:本文為轉載文章,轉載此文目的在于傳遞更多信息,版權歸原作者所有。本文所用視頻、圖片、文字如涉及作品版權問題,請聯系小編進行處理

審核編輯 黃宇

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 調試
    +關注

    關注

    7

    文章

    574

    瀏覽量

    33901
  • 無線MCU
    +關注

    關注

    2

    文章

    31

    瀏覽量

    17845
收藏 人收藏

    評論

    相關推薦

    各種無線供電方式匯總

    各種無線供電方式匯總
    發表于 08-20 17:28

    無線充電電源電路設計匯總

    無線充電電源電路設計匯總
    發表于 01-16 10:22

    無線充電技術大匯總

    無線充電技術大匯總
    發表于 07-22 20:18

    JTAG調試的知識點匯總,絕對實用

    JTAG調試的知識點匯總,絕對實用
    發表于 12-24 06:09

    MCU51的串口調試工具

    MCU51的串口調試工具:本站會員 gxujjd 及sltian 推薦的Mcu51網站的免費串口調試工具。此版本使用C++Builder編寫.
    發表于 01-16 11:53 ?126次下載

    DSP CCS初學調試問題匯總

    DSP CCS初學調試問題匯總,又需要的下來看看。
    發表于 05-06 15:32 ?0次下載

    Cypress16位MCU調試軟件

    本軟件是Cypress16位MCU調試軟件,可以在線燒寫程序。
    發表于 08-18 18:00 ?50次下載

    10個MCU常用的基礎知識匯總

    本文主要介紹了10個MCU常用的基礎知識匯總,具體的跟隨小編一起來了解一下。
    的頭像 發表于 10-05 09:39 ?1w次閱讀

    485調試助手_基于MM32 MCU的shell調試教程(一)

    對于做linux開發的研發人員來說,大家都喜歡通過輸入指令符來執行一些命令操作,如果在MCU編程過程中有一個類似linux的shell命令工具可以通過串口調試助手輸入命令然后運行一些調試函數,將會
    發表于 10-28 19:36 ?7次下載
    485<b class='flag-5'>調試</b>助手_基于MM32 <b class='flag-5'>MCU</b>的shell<b class='flag-5'>調試</b>教程(一)

    國產超低功耗華大MCU資料匯總

    國產超低功耗華大MCU資料匯總
    發表于 12-07 19:51 ?24次下載
    國產超低功耗華大<b class='flag-5'>MCU</b>資料<b class='flag-5'>匯總</b>

    MCU調試接口——怎么堵住這個后門?

    對于MCU的開發工程師來說,MCU調試接口是必不可少的開發利器。透過調試接口,我們可以監視MCU的運行狀態,查看或修改寄存器的數值,觀察內
    發表于 02-08 15:09 ?0次下載
    <b class='flag-5'>MCU</b>的<b class='flag-5'>調試</b>接口——怎么堵住這個后門?

    STM32 MCU TrustZone開發調試技巧分享

    電子發燒友網站提供《STM32 MCU TrustZone開發調試技巧分享.pdf》資料免費下載
    發表于 07-28 13:35 ?1次下載
    STM32 <b class='flag-5'>MCU</b> TrustZone開發<b class='flag-5'>調試</b>技巧分享

    HK32MCU應用筆記(六)| HK32MCU芯片調試心得

    HK32MCU應用筆記(六)| HK32MCU芯片調試心得
    的頭像 發表于 09-18 10:59 ?758次閱讀
    HK32<b class='flag-5'>MCU</b>應用筆記(六)| HK32<b class='flag-5'>MCU</b>芯片<b class='flag-5'>調試</b>心得

    MCU調試接口——怎么堵住這個后門?

    MCU調試接口——怎么堵住這個后門?
    的頭像 發表于 10-31 17:02 ?497次閱讀
    <b class='flag-5'>MCU</b>的<b class='flag-5'>調試</b>接口——怎么堵住這個后門?

    MCU不復位調試的小技巧

    場景,也并非無路可循。原則上只要我們通過仿真器調試時,做到代碼不被重新下載覆蓋,MCU 不被復位,就可能保留當前程序運行的狀態,讓 Bug 無處藏身。 02 實現方法 首先,我們將編譯完成的工程燒錄到 MCU,保證
    發表于 02-26 11:30 ?980次閱讀
    <b class='flag-5'>MCU</b>不復位<b class='flag-5'>調試</b>的小技巧