手把手教你搭建鸿蒙hi3518开发和运行环境

前言

学习C语言,C++语言,数据结构和算法,操作系统,网络,驱动,设计模式等知识

用鸿蒙来强化就太对了。本文教你一步一步搭建鸿蒙的开发和运行环境,有点啰嗦,适合小白。

本文所涉及的所有工具都可以在这里找到(提取码ue2a)

具体有下列步骤:

  • 组装开发板
  • 连接开发板
  • 安装串口驱动
  • 安装USB驱动
  • 安装烧录工具
  • 擦除引导程序
  • 烧录系统
  • 登录开发板
  • 修改OS启动地址
  • 运行可执行程序
  • 安装VMWARE
  • 安装编译服务器
  • 访问编译服务器
  • 编译鸿蒙产品
  • 编译鸿蒙组件
  • 打通开发板网络
  • 部署NFS
  • 新增自定义组件

组装开发板

我们选用HiSpark IPC DIY Camera产品。内部含hi3518ev300芯片。
请参考产品的安装说明书。

或者参考安装视频指导 

连接开发板

开发板和PC的连接关系如下图。2usb线(产品包装中的),其中一个三针插头,一个四针插头。

 

安装串口驱动
请双击USB-to-Serial Comm Port.exe。进行串口驱动安装,安装完成后。在设备管理器中应该能看到下面这样的COM接口,你的COM接口编号可能有所不同。表明串口驱动安装成功。

安装USB驱动

注意:有2USB驱动需要安装
双击zadig-2.5.exe安装通用USB驱动,点击中间的Install

 

安装第2USB驱动,这个驱动的名称是: HiUSBBurnDriver. 对应的安装文件已经放在网盘中,请自行安装。

上述2个驱动都安装成功以后,才能正常的进行USB烧录(往开发板烧录鸿蒙系统)。

安装烧录工具
直接解压HiTool-HM-5.4.9-win32-x86_64.zip文件。然后双击其中的HiTool.exe. 界面如下图。然后先将芯片切换到3518ev300

 

擦除引导程序
然后就是擦除uboot了,记得使用串口来擦除

有几点需要注意

  1. 由于编译服务器还没有创建,所以我把自己编译好的文件放网上了,你可以下载
  2. 文件路径根据你自己的实际路径,下载下来后存放的位置
  3. COM口根据你之前设备管理器看到的那个CH340口选择
  4. 确保顶部选中的芯片是3518ev300
  5. 传输方式选择串口
  6. 按分区烧写
  7. 器件类型spi nor
  8. 开始地址0,长度1M
  9. 点击擦除后10秒内拔插usb电源线接口(即接4个针脚的那个usb口,小的那个usb),让板子重启

很快就能看到擦除成功的提示

烧录系统

主要注意如下几点

  1. 使用usb口烧录(不是串口)
  2. 现在需要烧录4个文件(通过右侧绿色+可以添加文件)
  3. 每个文件的名称,器件类型,地址,长度要填写正确
  4. 最后点击烧写

然后等待烧写成功

 

如果你的烧写不成功,请检查之前的usb驱动是否已安装。

 

登录开发板
鸿蒙系统烧录好以后,就可以进去看一下鸿蒙系统的模样了。

双击MobaXterm_Personal_20.2.exe.  也可以用你自己喜欢的终端工具

然后点击Session, 在弹出的窗口中填好相关字段

点击OK以后,会进入下面这个界面

这里是uboot程序的界面,还没有进入鸿蒙OS,原因是uboot此时不知道鸿蒙OS的启动地址。

然后我们设置启动地址

设置OS启动地址

setenv bootcmd "sf probe 0;sf read 0x40000000 0x100000 0x600000;go 0x40000000";

setenv bootargs "console=ttyAMA0,115200n8 root=flash fstype=jffs2 rw rootaddr=7M rootsize=8M";

保存配置

saveenv

然后重启

然后,很快就可以看到鸿蒙OS起来了

如果你没有看到OHOS#字样,请按下几次enter键。接下来,我们手动运行一个鸿蒙的程序。

运行可执行程序

进入bin目录,运行writer程序(这个程序是我新增的,如果你的开发板上没有,你可以运行./camera_app程序)

创建编译服务器
为了省去搭建编译环境的繁琐,本次将一个已经搭建好的编译服务器制作成镜像。我们只需要使用这个镜像即可获得编译环境。

镜像文件比较大(超过8G),请直接找老师获取,也可以去前言提到的地方下载(建议晚上睡觉时下载)

本次使用的Ubuntu是不带桌面环境的。内部已经安装好HarmonyOS的编译环境,并且安装了samba文件共享工具。方便windows访问。

请先安装VMWARE WorkStation软件

然后打开它, 选择 文件-->打开

然后开始了服务器创建过程,这个过程比较漫长,请保持耐心。

访问服务器
服务器创建完成后。然后我们对它进行上电启动

等待服务器开机。1分钟内一般就能正常起来。这个过程中,注意保持网线插入,因为虚拟机和PC之间是通过有线网卡桥接的。启机过程有软件会探测网络是否在,否则会很慢。

当屏幕输出变慢后,我们就可以访问它了,当然也可以在黑窗口里面直接键入各种命令,不过不方便。

把鼠标放入黑窗口,点击以后,鼠标焦点就进入黑窗口了,让焦点退出来的方法是按CTRL+g

 

如果想在黑窗口操作linux相关命令,则键入用户名compile  密码compile

一般我们不在黑窗口操作。

我们需要如下2种方法来访问虚拟机:

  1. 通过ssh访问,即可以远程登录虚拟机的shell,并执行命令
  2. 通过文件共享访问,可以在windows上查看和修改虚拟机中的文件

注意:

  1. 当前创建的虚拟机采用的是桥接模式,它的IP地址为192.168.2.20。你需要确保虚拟机中的IP地址和自己PCIP地址在同一个网段。(最简单的方法是在自己的网卡上添加一个192.168.2.X网段的IP地址)Windows添加IP地址的方法请自行查阅。
  2. 如果多台编译服务器在同一个局域网络,那么IP地址会冲突,因为都是192.168.2.20。所以,需要对地址进行修改。

SSH访问

点击OK以后,就登录到了编译服务器的shell

文件共享访问

为了从Windows访问编译服务器上的源代码和编译出的目标文件,在编译服务器上已经安装好了samba文件共享服务,只需要在windows这边映射网络驱动器即可。按如下方法操作。

右键点击 计算机 ,选择映射网络驱动器。

然后就可以在windows看到编译服务器上的内容了。

现在开始,你就可以像操作windows的文件一样来操作编译服务器里面的文件了(比如通过Visual Studio来修改服务器上的C/C++代码文件)

编译产品

整个工程是存放在~/harmonyos/openharmony目录,

得先进入这个目录。

然后执行python脚本来编译产品。如下红色框即编译整个产品。

特别提醒:

python build.py ipcamera_hi3518ev300 -b debug

编译debug版本才会含有调试的shell,如果省略-b debug,无法通过shell命令行执行命令。

大约需要10多分钟完成产品编译,编译成功后,结果如下。

然后在windows文件夹下可以看到编译出来的结果

每次系统烧录时,将上述3个文件以及uboot文件(Z:\vendor\hisi\hi35xx\hi3518ev300\uboot\out\boot\u-boot-hi3518ev300.bin)

拷贝到windows某个目录下(比如我的例子中的D:\BIN),然后用HiTool.exe来烧录。

更新源码
鸿蒙系统目前更新比较频繁,如果需要获取最新版本,请执行下面的命令更新源码。

这里有一个问题:编译服务器预设的192.168.2.20无法上网。这个时候你可以再添加1IP地址(添加可以上网的IP地址)。然后再执行下面2条命令

cd ~/harmonyos/openharmony

repo sync -c

。。。待贴图。。。

 

编译组件
编译完整产品比较耗时,大多数时候我们修改的代码较少,只需要编译指定的组件就行了。

-T指定编译一个已经存在的组件,只编译一个小组件,速度飞快。

注意,编译组件的时候 -T 后面的路径需要使用全路径。如何确定-T后面的参数?请看下图

文本编辑器(notepad++)打开build/lite/product/ ipcamera_hi3518ev300.json文件

这个组件涉及的代码文件是哪些呢,继续看对应目录的BUILD.gn文件,对于此例子为//applications/sample/camera/app

生成的程序在下面这个目录

打通网络

设备本身没有以太口,只有wifi接口。但默认情况下wifi是无法工作的。

输入ifconfig你会看到wlan0接口IP地址为0

               

需要做如下工作才能让wifi正常运行起来。

  • 配置SSID和密码
  • 修改wpa_sample.c源码
  • 配置自启动
  • 编译系统

 

配置SSID和密码
修改applications\sample\camera\communication\wpa_supplicant\config\ wpa_supplicant.conf

修改后的内容如下。这个文件的目的是配置wifi用户名和密码

country=GB

ctrl_interface=udp

network={

        ssid="teacher"

        psk="12345678qwe"

    }

注意

  • =2端不要留空格
  • ssidpsk按你自己的实际进行配置,比如你手机热点的网络名和密码。

 

修改源码
修改applications\sample\camera\communication\wpa_supplicant\src\wpa_sample.c源代码

只修改main函数部分。这个程序的目的是读取wifi用户名和密码配置文件,并进行wifi连接。

int main(int argc, char *argv[])

{

    g_wpaArgc = argc;

    for (int i = 0; i < g_wpaArgc; i++) {

        g_wpaArg[i] = argv[i];

    }

    g_wpaArgc=5;

    g_wpaArg[1] = "-i";

    g_wpaArg[2]="wlan0";

    g_wpaArg[3]="-c";

    g_wpaArg[4]="/etc/wpa_supplicant.conf";

    int ret = pthread_create(&g_wpaThread, NULL, ThreadMain, NULL);

    if (ret != 0) {

        printf("[WpaSample]create thread failed error:%s.\n", strerror(ret));

        return 1;

    }

    pthread_join(g_wpaThread, NULL);

    return 0;

}

复制

配置自启动
刚才修改的main会生成一个可执行程序,这个程序我们需要把它配置在启动脚本中,这样每次板子重启都会运行这个程序

修改文件vendor\huawei\camera\init_configs\ init_liteos_a_3518ev300.cfg   红色部分为新增

{
    "jobs" : [{
            "name" : "pre-init",
            "cmds" : [
                "mkdir /storage/data/log",
                "chmod 0755 /storage/data/log",
                "chown 4 4 /storage/data/log",
                "mkdir /storage/data/softbus",
                "chmod 0700 /storage/data/softbus",
                "chown 7 7 /storage/data/softbus",
                "mkdir /sdcard",
                "chmod 0777 /sdcard",
                "mount vfat /dev/mmcblk0 /sdcard rw,umask=000",
                "mount vfat /dev/mmcblk1 /sdcard rw,umask=000"
            ]
        }, {
            "name" : "init",
            "cmds" : [
                "start shell",
                "start apphilogcat",
                "start foundation",
                "start bundle_daemon",
                "start media_server",
                "start appspawn",
  
"start wpa_supplicant"

            ]
        }, {
            "name" : "post-init",
            "cmds" : [
                "chown 0 99 /dev/dev_mgr",
                "chown 0 99 /dev/hdfwifi",
                "chown 0 99 /dev/gpio",
                "chown 0 99 /dev/i2c-0",
                "chown 0 99 /dev/i2c-1",
                "chown 0 99 /dev/i2c-2",
                "chown 0 99 /dev/uartdev-0",
                "chown 0 99 /dev/uartdev-1",
                "chown 0 99 /dev/uartdev-2",
                "chown 0 99 /dev/spidev0.0",
                "chown 0 99 /dev/spidev1.0",
                "chown 0 99 /dev/spidev1.1"
            ]
        }
    ],
    "services" : [{
            "name" : "foundation",
            "path" : "/bin/foundation",
            "uid" : 7,
            "gid" : 7,
            "once" : 0,
            "importance" : 1,
            "caps" : [10, 11, 12, 13]
        }, {
            "name" : "shell",
            "path" : "/bin/shell",
            "uid" : 2,
            "gid" : 2,
            "once" : 0,
            "importance" : 0,
            "caps" : [4294967295]
        }, {
            "name" : "appspawn",
            "path" : "/bin/appspawn",
            "uid" : 1,
            "gid" : 1,
            "once" : 0,
            "importance" : 0,
            "caps" : [2, 6, 7, 8, 23]
        }, {
            "name" : "apphilogcat",
            "path" : "/bin/apphilogcat",
            "uid" : 4,
            "gid" : 4,
            "once" : 1,
            "importance" : 0,
            "caps" : []
        }, {
            "name" : "media_server",
            "path" : "/bin/media_server",
            "uid" : 5,
            "gid" : 5,
            "once" : 1,
            "importance" : 0,
            "caps" : []
        }, {
            "name" : "wms_server",
            "path" : "/bin/wms_server",
            "uid" : 6,
            "gid" : 6,
            "once" : 1,
            "importance" : 0,
            "caps" : []
        }, {
            "name" : "bundle_daemon",
            "path" : "/bin/bundle_daemon",
            "uid" : 8,
            "gid" : 8,
            "once" : 0,
            "importance" : 0,
            "caps" : [0, 1]
        }
,{
     "name": "wpa_supplicant",
     "path": "/bin/wpa_supplicant",
     "uid" : 0,
     "gid" :  0,
     "once" : 1, 
     "importance" : 0,
     "caps": [] 
 }
    ]
}

wifi功能参与编译

编译wifi模块的时候,要修改build/lite/product/ ipcamera_hi3518ev300.json文件,才能让wpa_supplicant这个模块参与编译,修改如下:

 

编译系统

此时我们配置好了wifi用户名和密码,也修改了wifi启动程序并设置好了启动脚本。接下来我们把这些修改编译到系统中,然后再烧录到板子上

当完整编译系统,烧录好以后,新版本的系统起来以后,我们可以看到wlan0 的接口的IP地址正常获取到了。

部署NFS
当网络打通以后,我们就可以部署NFS(网络文件系统)了。部署NFS最大的好处是,可以将windows的某个文件夹当成开发板上的文件夹来使用,这样,不需要把编译的程序手动拷贝到开发板去,就可以执行编译出来的程序。

主要分为如下3个过程

  1. 安装NFS Server
  2. 配置和启动Server
  3. 挂载NFS

安装NFS
PC上安装NFS服务器。双击nfs1169.exe进行安装,同常规软件安装方法。

配置NFS
安装好以后,就是配置了,这一步稍微麻烦。首先需要以管理员身份运行NFS服务器

开始-->所有程序-->haneWIN软件-->NFS-->NFS服务器(右键点击)--选择(以管理员身份运行)

编辑输出表文件。如下。

然后保存

然后我们配置防火墙,使得NFS相关的网络通信畅通。先看需要放行哪些端口。

需要放行的端口有: 111, 1058, 2049. TCPUDP都需要。

然后我们配置放行这些端口(即允许这些端口的流量通过)

控制面板\系统和安全\Windows 防火墙

 

确保规则已配置好。然后重启防火墙(关闭防火墙,再打开防火墙)

重启NFS

开始---所有程序---haneWIN软件---NFS---重启所有服务(以管理员身份运行)

挂载NFS

在开发板shell界面,挂载NFS

先确保开发板和PC之间能互通(可以从PC ping开发板)。我的开发板和PC都通过wifi连接手机热点,所以在一个网段,能互相ping通。

然后开发板上面执行下面的命令。

除了IP地址调整成你PC的地址,其它信息照抄。挂载成功会显示finished如红框所示。

然后我们就可以执行windows上的程序了。

在我的机器上,上述文件存放在d:\BIN目录。因为这个目录我配置成了NFS Server的根目录

所以,能从开发板上看到并运行它们。

上述这些内容,是通过从编译服务器拷贝出来的。如何拷贝,请参阅访问虚拟机章节。

 

添加组件

如果我们要新增程序怎么处理。请仿照范例中的camer_app处理。具体如下,比如我新增了一个reader程序,一个writer程序。以下描述reader的添加逻辑。

 

applications\sample\camera目录下,将app目录复制一份,改名为reader

然后修改reader里面的文件。先修改BUILD.gn

然后源码根据自己的实际情况修改。

最后修改编译脚本build\lite\product\ ipcamera_hi3518ev300.json

添加红框中的一行,然后按组件编译方式编译就可以了。

编译好的程序在out\ipcamera_hi3518ev300\bin目录下

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Android平台上使用FFmpeg需要进行交叉编译,生成适用于Android的FFmpeg库,并将其打包到apk中。以下是手把手搭建ffmpeg命令行运行环境的步骤: 1.下载NDK 首先需要下载NDK(Native Development Kit),NDK是一个工具包,用于开发C/C++应用程序的原生库。Android Studio自带NDK,也可以从官网下载。 2.下载FFmpeg源代码 从FFmpeg的官网下载源代码,然后解压到本地。 3.配置交叉编译环境 在FFmpeg源代码根目录下创建一个build_android.sh文件,输入以下内容: ```bash #!/bin/bash NDK=$HOME/Android/Sdk/ndk-bundle # NDK路径 SYSROOT=$NDK/platforms/android-21/arch-arm/ # Android SDK路径 TOOLCHAIN=$NDK/toolchains/arm-linux-androideabi-4.9/prebuilt/linux-x86_64 # 工具链路径 function build_one { ./configure \ --prefix=$PREFIX \ --enable-shared \ --disable-static \ --disable-doc \ --disable-ffmpeg \ --disable-ffplay \ --disable-ffprobe \ --disable-ffserver \ --disable-debug \ --disable-network \ --disable-avdevice \ --disable-postproc \ --disable-symver \ --cross-prefix=$TOOLCHAIN/bin/arm-linux-androideabi- \ --target-os=android \ --arch=arm \ --sysroot=$SYSROOT \ --extra-cflags="-Os -fpic $ADDI_CFLAGS" \ --extra-ldflags="$ADDI_LDFLAGS" \ $ADDITIONAL_CONFIGURE_FLAG make make install } CPU=arm PREFIX=$(pwd)/android/$CPU ADDI_CFLAGS="-marm" ADDI_LDFLAGS="" build_one ``` 其中,NDK是NDK的路径,SYSROOT是Android SDK的路径,TOOLCHAIN是工具链的路径。 4.执行交叉编译命令 在终端中输入以下命令: ```bash chmod +x build_android.sh ./build_android.sh ``` 等待编译完成。编译完成后,在FFmpeg源代码根目录下会生成一个android目录,其中包含了交叉编译生成的FFmpeg库。 5.创建Android Studio项目 打开Android Studio,创建一个新项目。在app/build.gradle文件中添加以下代码: ```groovy android { compileSdkVersion 28 defaultConfig { applicationId "com.example.ffmpegdemo" minSdkVersion 21 targetSdkVersion 28 versionCode 1 versionName "1.0" testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" } buildTypes { release { minifyEnabled false proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro' } } externalNativeBuild { cmake { cppFlags "" abiFilters "armeabi-v7a" arguments "-DANDROID_ARM_NEON=TRUE" } } sourceSets.main { jniLibs.srcDirs = ['src/main/jniLibs'] } ndk { abiFilters "armeabi-v7a" } } ``` 其中,externalNativeBuild和ndk是用于指定使用交叉编译生成的库的配置。 6.将FFmpeg库打包到apk中 将交叉编译生成的库复制到项目的app/src/main/jniLibs/armeabi-v7a/目录下。在app/build.gradle文件中添加以下代码: ```groovy android { sourceSets { main { jniLibs.srcDirs = ['src/main/jniLibs'] } } } ``` 然后在终端中输入以下命令: ```bash ./gradlew assembleDebug ``` 等待打包完成。打包完成后,在项目的build/outputs/apk/debug/目录下会生成一个apk文件,其中包含了FFmpeg库。 至此,就完成了搭建ffmpeg命令行运行环境的所有步骤。可以通过在MainActivity中执行FFmpeg命令来测试FFmpeg是否正常工作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值