最激动入门级选手的心的时刻来了,本示例将演示如何编写简单业务,输出“Hello World”。

  • 4.编写模块BUILD.gn文件,指定需参与构建的特性模块。

    配置./applications/sample/wifi-iot/app/BUILD.gn文件,在features字段中增加索引,使目标模块参与编译。features字段指定业务模块的路径和目标,以my_first_app举例,features字段配置如下。


    import("//build/lite/config/component/lite_component.gni")

    lite_component("app") {
        features = [
            "my_first_app:myapp",
        ]
    }

    调测验证

    目前调试验证的方法有两种,分别为通过printf打印日志、通过asm文件定位panic问题,开发者可以根据具体业务情况选择。

    由于本示例业务简单,采用printf打印日志的调试方式即可。下面开始介绍这两种调试手段的使用方法。

    printf打印

    代码中增加printf维测,信息会直接打印到串口上。开发者可在业务关键路径或业务异常位置增加日志打印,如下所示。


    void HelloWorld(void)
    {
        printf("[DEMO] Hello world.\n");
    }

    根据asm文件进行问题定位

    系统异常退出时,会在串口上打印异常退出原因调用栈信息,如下文所示。通过解析异常栈信息可以定位异常位置。


    =======KERNEL PANIC=======
    **********************Call Stack*********************
    Call Stack 0 -- 4860d8 addr:f784c
    Call Stack 1 -- 47b2b2 addr:f788c
    Call Stack 2 -- 3e562c addr:f789c
    Call Stack 3 -- 4101de addr:f78ac
    Call Stack 4 -- 3e5f32 addr:f78cc
    Call Stack 5 -- 3f78c0 addr:f78ec
    Call Stack 6 -- 3f5e24 addr:f78fc
    ********************Call Stack end*******************

    为解析上述调用栈信息,需要使用到Hi3861_wifiiot_app.asm文件,该文件记录了代码中函数在Flash上的符号地址以及反汇编信息。asm文件会随版本大包一同构建输出,存放在./out/wifiiot/路径下。

    1.将调用栈CallStack信息保存到txt文档中,以便于编辑。(可选)

    2.打开asm文件,并搜索CallStack中的地址,列出对应的函数名 信息。通常只需找出前几个栈信息对应的函数,就可明确异常代码方向。


    Call Stack 0 -- 4860d8 addr:f784c -- WadRecvCB
    Call Stack 1 -- 47b2b2 addr:f788c -- wal_sdp_process_rx_data
    Call Stack 2 -- 3e562c addr:f789c
    Call Stack 3 -- 4101de addr:f78ac
    Call Stack 4 -- 3e5f32 addr:f78cc
    Call Stack 5 -- 3f78c0 addr:f78ec
    Call Stack 6 -- 3f5e24 addr:f78fc

    3.根据以上调用栈信息,可以定位WadRecvCB函数中出现了异常。尝鲜!我在华为鸿蒙上编写的第一个 Hello World!-LMLPHP4.完成代码排查及修改。

    运行结果

    示例代码编译、烧录、运行、调测后,会显示如下结果


    ready to OS start
    FileSystem mount ok.
    wifi init success!
    [DEMO] Hello world.
    
    
    
    
    
    
    
       
    
    
    
    
    
    
    
        
    
    
    
       

    ▐往期推荐 

    尝鲜!我在华为鸿蒙上编写的第一个 Hello World!-LMLPHP

    如果你觉得文章不错,文末的赞 👍 又回来啦,记得给我「点赞」和「在看」哦~




    本文分享自微信公众号 - JAVA高级架构(gaojijiagou)。
    如有侵权,请联系 [email protected] 删除。
    本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

    03-30 00:19