鸿蒙Hi3861学习三-第一个实例程序Hello_world

一、简介

        前两章介绍了环境搭建、烧录和编译。这一节,来介绍实现第一个经典代码“hello world”。

        先介绍小熊派的目录结构,该目录结构延续了OpenHarmony官方目录结构。

二、实操

        1.搭建代码架构

        1).新建项目文件夹hello_world

cd bearpi-hm_nano/applications/BearPi/BearPi-HM_Nano/sample/
mkdir hello_world

        创建hello_world目录,用来存放业务源码文件

        2).新增hello_world.c文件

cd hello_world
touch hello_world.c

        创建hello_world.c文件,该文件为业务源码文件

        3).新增BUILD.gn文件

touch BUILD.gn

        创建BUILD.gn文件,该文件为业务源码编译脚本

        4).最终代码架构展示

.
└── applications        
    └── BearPi
        └── BearPi-HM_Nano
            └── sample
                │── hello_world
                │  │── hello_world.c
                │  └── BUILD.gn
                └── BUILD.gn

        2.代码编写

        1).编写业务代码

        在hello_world.c文件中增加如下代码:

#include <stdio.h>
#include "ohos_init.h"

void Hello_World(void)
{
    printf("this is a test demo \r\n Hello World!\r\n");
}

APP_FEATURE_INIT(Hello_World);

        APP_FEATURE_INITOpenHarmony启动恢复模块接口,该接口用来启动业务。也可以使用SYS_RUN来实现,效果是一样的。(APP_FEATURE_INIT和SYS_RUN定义都在ohos_init.h)文件中。

        2).编写用于将业务构建成静态库的BUILD.hn文件

        在hello_world文件夹的BUILD.gn文件中添加如下代码:

static_library("hello_world"){
    sources = [
        "hello_world.c"
    ]
    include_dirs = [
        "//utild/native/lite/include"
    ]
}

        该文件由三部分内容构成,目标源文件头文件路径

        static_library:该文件中指定业务模块的编译结果,为静态库文件libhello_world.a。

         sources:该文件中指定静态库.a所依赖的.c文件及路径,若路径中包含“//”则表示绝对路径代码的根路径,即bearpi-hm_nano文件夹)。若不包含“//”则表示相对路径。

         incllude_dirs:该文件中指定source所依赖的.h文件路径

         3).编写模块BUILD.gn文件,指定需要参与构建的特性模块

        配置sample文件夹中的BUILD.gn文件。在features字段中增加索引"hello_world:hello_world",使目标模块参与编译

        注意屏蔽其他模块

#"Zx_Developer:zx_develop_sample"  ##不参与构建,为开发者贡献演示结构,其中Zx为 Z1,Z2...Z100
        #"Z1_hi3861_uart_ylc:uart_hi3861",
        #"Z2_hi3861_flash_ylc:flash_example",

        "hello_world:hello_world"

        hello_world(前):是相对路径,指向./applications/BearPi/BearPi-HM_Nano/sample/hello_world/BUILD.gn

        hello_world(后):指向 ./applications/BearPi/BearPi-HM_Nano/sample/hello_world/BUILD.gn 中的static_library("hello_world")

        2.编译

        在项目根目录下,运行编译代码:

python build.py BearPi-HM_Nano

         编译成功。

        编译结束后,会在Out/工程名 文件下生成bin文件。

        这里介绍一个各个文件

文件名说明备注
Hi3861_boot_signed.bin签名的bootloader文件        Flash boot
Hi3861_boot_signed_B.bin签名的bootloader备份文件Flash boot备份
Hi3861_wifiiot_app.asmKernel asm文件汇编程序源文件
Hi3861_wifiiot_app.mapKernel map文件程序的全局符号,函数的地址,占用的空间等,用于调试。例如程序崩溃就可以查看这个文件
Hi3861_wifiiot_app.outKernel 输出文件
Hi3861_wifiiot_app_allinone.bin产线烧录文件包含了独立烧写程序和loader程序

包含了2个bin:

Hi3861_boot_signed.bin

Hi3861_wifiiot_app_burn.bin

Hi3861_wifiiot_app_burn.binKernel烧写文件,建议直接使用Hi3861_wifiiot_app_allinone.bin默认包含boot、NV、可执行程序镜像
Hi3861_wifiiot_app_flash_boot_ota.binFlash Boot升级文件
Hi3861_wifiiot_app_ota.binKernel升级文件
Hi3861_wifiiot_app_vercfg.binKernel和Boot的版本号文件
Hi3861_loader_signed.bin烧写工具使用的加载文件只用在烧写,位于内存中。烧写至少需要Hi3861_boot_signed.bin和Hi3861_wifiiot_app_burn.bin这两个文件。Hi3861_wifiiot_app_allinone.bin包含了这两个文件,所以推荐使用allinone文件进行烧录。

        3.烧录

        

         4.复位开发板并查看LOG输出

         完成!!!

TMS320C6713是德州仪器(TI)公司的一款DSP处理器,可以用于嵌入式系统的开发。EMIF(External Memory Interface)是该处理器的外部存储接口,可以通过连接闪存(Flash)来实现代码和数据的存储。在TMS320C6713处理器上,我们可以通过将Flash的镜像文件固化到EMIF来实现程序的运行。 首先,我们需要生成Flash的镜像文件。镜像文件是一个包含程序和数据的二进制文件,可以通过编译器或者烧录工具生成。生成镜像文件时,需要指定程序的起始地址和大小,以及数据的存储位置和大小等信息。 接下来,我们需要将生成的镜像文件固化到EMIF。固化镜像文件的步骤如下: 1. 准备一台能够与TMS320C6713处理器连接的电脑或者开发板,并安装好相应的开发环境和工具。 2. 将Flash的镜像文件拷贝到电脑或者开发板。 3. 使用相应的烧录工具或者命令行工具,将镜像文件烧录到EMIF。具体的烧录方法和工具取决于开发环境和开发板的配置。 4. 等待烧录完成,并进行必要的验证和测试。可以通过读取EMIF中存储的数据来验证镜像文件是否正确固化到了EMIF。 需要注意的是,固化镜像文件到EMIF之前,应该先确保EMIF的设置和配置正确,包括EMIF的时钟频率、数据位宽、存储器类型等。根据具体的开发环境和要求,可能需要进行相关的设置和调整。 总结起来,固化TMS320C6713处理器上的Flash镜像文件到EMIF可以通过生成镜像文件和使用烧录工具完成。这样,我们就能够将程序和数据存储到外部的Flash中,并通过EMIF访问和执行这些程序和数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值