OpenHarmony之hdc

2024-01-09 21:46:33

OpenHarmony之hdc

简介

hdc(OpenHarmony Device Connector)是 OpenHarmony 为开发人员提供的用于调试的命令行工具,通过该工具可以在Windows/Linux/MacOS等系统上与开发机或者模拟器进行交互。

类似于Android的adb,和adb类似,使用hdc的前提是开发机器hdc工具已安装好,设备端hdc已安装且已配置好。

开发机HDC

开发机hdc工具通过OpenHarmony sdk获取,hdc在sdk的 toolchains目录下

这里我对应的是OpenHarmony-3.2-Release的 ohos-sdk-full

解压:

zdd@xxx-PC:~/WorkSpace/OHOS/ohos-sdk$ tree
.
├── linux
│   ├── ets-linux-x64-3.2.15.3-Release.zip
│   ├── js-linux-x64-3.2.15.3-Release.zip
│   ├── native-linux-x64-3.2.15.3-Release.zip
│   ├── previewer-linux-x64-3.2.15.3-Release.zip
│   └── toolchains-linux-x64-3.2.15.3-Release.zip
└── windows
    ├── ets-windows-x64-3.2.15.3-Release.zip
    ├── js-windows-x64-3.2.15.3-Release.zip
    ├── native-windows-x64-3.2.15.3-Release.zip
    ├── previewer-windows-x64-3.2.15.3-Release.zip
    └── toolchains-windows-x64-3.2.15.3-Release.zip

根据自己使用的系统,继续解压对应的 toolchains压缩包,hdc等工具就在 toolchains里面。

设备端HDC

设备端hdc工具一般会随编译构建打包进文件系统。

设备端配置分2种不同的通路:USB或网络

  • USB的话,主要保证USB能用能通(驱动OK),使能USB的 otg模式或 peripheral 模式,并通过configfs配置好usb相关的参数并启动对应服务,一般是用init的cfg文件来配,例如rk3588的为 init.rk3568.usb.cfg,这里不详细展开了
    {
        "jobs" : [{
                "name" : "boot",
                "cmds" : [
                    "mkdir /dev/usb-ffs 0770 shell shell",
                    "mkdir /dev/usb-ffs/hdc 0770 shell shell",
                    "mount configfs none /config",
                    "mkdir /config/usb_gadget/g1 0770 shell shell",
                    "write /config/usb_gadget/g1/idVendor 0x2207",
                    "write /config/usb_gadget/g1/idProduct 0x0018",
                    "write /config/usb_gadget/g1/os_desc/use 1",
                    "write /config/usb_gadget/g1/bcdDevice 0x0223",
                    "write /config/usb_gadget/g1/bcdUSB 0x0200",
                    "mkdir /config/usb_gadget/g1/strings/0x409 0770",
                    "copy /sys/block/mmcblk0/device/cid /config/usb_gadget/g1/strings/0x409/serialnumber",
                    "write /config/usb_gadget/g1/strings/0x409/manufacturer Rockchip",
                    "write /config/usb_gadget/g1/strings/0x409/product \"HDC Device\"",
                    "mkdir /config/usb_gadget/g1/functions/ffs.hdc",
                    "mkdir /config/usb_gadget/g1/configs/b.1 0770 shell shell",
                    "mkdir /config/usb_gadget/g1/configs/b.1/strings/0x409 0770 shell shell",
                    "write /config/usb_gadget/g1/os_desc/b_vendor_code 0x1",
                    "write /config/usb_gadget/g1/os_desc/qw_sign MSFT100",
                    "write /config/usb_gadget/g1/configs/b.1/MaxPower 500",
                    "symlink /config/usb_gadget/g1/configs/b.1 /config/usb_gadget/g1/os_desc/b.1",
                    "mount functionfs hdc /dev/usb-ffs/hdc uid=2000,gid=2000",
                    "setparam sys.usb.configfs 1",
                    "setparam sys.usb.controller fcc00000.dwc3"
                ]
            }, {
                "name" : "param:sys.usb.config=none && param:sys.usb.configfs=1",
                "condition" : "sys.usb.config=none && sys.usb.configfs=1",
                "cmds" : [
                    "write /config/usb_gadget/g1/os_desc/use 0",
                    "setparam sys.usb.ffs.ready 0"
                ]
            }, {
                "name" : "param:init.svc.hdcd=stopped",
                "condition" : "init.svc.hdcd=stopped",
                "cmds" : [
                    "setparam sys.usb.ffs.ready 0"
                ]
            }, {
                "name" : "param:sys.usb.config=hdc && param:sys.usb.configfs=1",
                "condition" : "sys.usb.config=hdc && sys.usb.configfs=1",
                "cmds" : [
                    "write /config/usb_gadget/g1/idProduct 0x5000",
                    "write /config/usb_gadget/g1/os_desc/use 1"
                ]
            }
        ]
    }
  • 网络的话,主要保证网络能用能通(驱动OK),配置好网络IP等,设置hdc参数(主要是模式和端口),并启动hdcd服务,通过命令的方式如下,也可通过配置文件的方式:
    # 设置hdc参数
    param set persist.hdc.mode tcp
    param set persist.hdc.port xxxx
    # 启动hdcd服务
    hdcd &

    一些常用命令

    当两端都配置好之后就可以愉快地使用hdc工具了,下面列举了一些常用的命令,更多说明详见官方文档或help:

    #查询设备列表(-v 打印设备详细信息)
    hdc list targets[-v]
    
    #通过【ip地址:端口号】来连接指定的设备(-remove 断开与指定设备的连接)
    hdc tconn host[:port][-remove] 
    #设备端对应daemon进程重启,并首先选用USB连接方式
    hdc tmode usb
    
    #调试
    hdc shell
    hdc hilog
    
    #以读写模式挂载系统分区
    hdc target mount
    
    #设备重启
    hdc target boot
    
    #授予后台服务进程root权限, 使用-r参数取消授权
    hdc smode
    hdc smode -r
    
    #发送文件至远端设备
    hdc file send ./a.txt /data/local/tmp/a.txt
    #从远端设备接收文件至本地
    hdc file recv /data/local/tmp/a.txt ./a.txt
    
    #安装HAP(-r 替换已存在应用 -d 允许降级安装 -g 应用动态授权)
    hdc install [-r/-d/-g] package
    #卸载HAP -k 保留/data/cache
    hdc uninstall [-k] package

    总结

    以上的内容主要简单介绍了《OpenHarmony之hdc》的教程

    要想成为一名鸿蒙高级开发,以上知识点是必须要掌握的,除此之外,还需要掌握一些鸿蒙应用开发相关的一些技术,需要我们共同去探索。

    为了节省大家一些查找的时间,这边联合几位行业大佬,为大家准备了一份《Open Harmony4.0&Next》的学习导图从入门到进阶再到南北向开发实战的一整套完整体系,想要学习了解更多鸿蒙开发的相关知识可以借鉴:

    除了以上的知识内容,我还为大家整理了一份《鸿蒙 (Harmony OS)开发学习手册》都是整理成PDF文档方式,分享给大家参考学习:《做鸿蒙应用开发到底学习些啥?》

    《鸿蒙 (Harmony OS)开发学习手册》

    一、入门必看

    1. 应用开发导读(ArkTS)

    2. 应用开发导读(Java)

    3.......

    二、HarmonyOS 概念

    1. 系统定义

    2. 技术架构

    3. 技术特性

    4. 系统安全

    5......

    三、如何快速入门?《鸿蒙基础入门开发宝典!》

    1. 基本概念

    2. 构建第一个ArkTS应用

    3. 构建第一个JS应用

    4. ……

    四、开发基础知识

    1. 应用基础知识

    2. 配置文件

    3. 应用数据管理

    4. 应用安全管理

    5. 应用隐私保护

    6. 三方应用调用管控机制

    7. 资源分类与访问

    8. 学习ArkTS语言

    9. ……

    五、基于ArkTS 开发

    1. Ability开发

    2. UI开发

    3. 公共事件与通知

    4. 窗口管理

    5. 媒体

    6. 安全

    7. 网络与链接

    8. 电话服务

    9. 数据管理

    10. 后台任务(Background Task)管理

    11. 设备管理

    12. 设备使用信息统计

    13. DFX

    14. 国际化开发

    15. 折叠屏系列

    16. ……

    更多了解更多鸿蒙开发的相关知识可以参考:《鸿蒙开发学习指南》

文章来源:https://blog.csdn.net/m0_70749039/article/details/135489338
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。