1# device_soc_telink 2 3- [简介](#简介) 4- [开发环境](#开发环境) 5- [安装工具](#安装工具) 6- [获取源码](#获取源码) 7- [确认目录结构](#确认目录结构) 8- [编译工程](#编译工程) 9- [烧录固件](#烧录固件) 10- [相关仓库](#相关仓库) 11 12## 简介 13 14本仓库为泰凌微电子(Telink Semi)公司的TLSR9系列芯片相关代码仓库,用于存放与SoC芯片相关的SDK及适配代码。 15使用同一系列SoC,开发不同的device或board时,可共用该仓库代码进行开发。 16 17## 开发环境 18 19推荐采用Windows+Ubuntu环境进行开发: 20 21- Windows环境用于编写代码、下载程序和烧入固件等,系统要求:Windows 10 64位系统。 22 23- Linux环境用于代码下载、编译工程和生成固件等,系统要求:Ubuntu 20.04 64位及以上版本。 24 25 - 若不确定所使用的Linux设备的系统及版本,请在bash中运行如下命令查看: 26 27 ```bash 28 lsb_release -a 29 ``` 30 31 - 请在确认Linux系统不低于`Ubuntu 20.04.XX LTS`的情况下执行后续的步骤;否则,请升级或更换合适的Liunx设备。 32 33> 若需要支持在Linux与Windows之间的文件共享以及编辑,请在Linux设备上适当地安装和配置samba、vim等常用软件。 34 35## 安装工具 36 37本仓库包含的编译构建脚本和打包镜像工具等,需要在Linux环境上执行。 38 39本章节参考了OpenHarmony文档《搭建轻量与小型系统》,[请点击查看详情](https://gitee.com/openharmony/docs/blob/master/zh-cn/device-dev/quick-start/quickstart-lite-env-setup.md)。 40 41### 安装repo 42 43码云repo是一种代码版本管理工具,可以用来打包获取OpenHarmony的源码。 44 451. 在home文件夹下创建repo安装目录: 46 47 ```bash 48 mkdir ~/bin 49 ``` 50 512. 下载repo至安装目录: 52 53 ```bash 54 wget https://storage.googleapis.com/git-repo-downloads/repo -P ~/bin/ 55 ``` 56 573. 改变执行权限: 58 59 ```bash 60 chmod a+x ~/bin/repo 61 ``` 62 634. 在~/.bashrc文件的末尾,额外加入以下内容,配置环境变量: 64 65 ```bash 66 # set environment for repo 67 export PATH=~/bin:$PATH 68 export REPO_URL=https://mirrors.tuna.tsinghua.edu.cn/git/git-repo/ 69 ``` 70 715. 重启bash或执行以下命令让环境变量生效: 72 73 ```bash 74 source ~/.bashrc 75 ``` 76 77### 安装常用库和工具 78 79使用如下apt-get命令安装后续操作所需的库和工具,用于编译C/C++代码: 80 81```bash 82sudo apt-get install build-essential gcc g++ make zlib* libffi-dev e2fsprogs pkg-config flex bison perl bc openssl libssl-dev libelf-dev libc6-dev-amd64 binutils binutils-dev libdwarf-dev u-boot-tools mtd-utils gcc-arm-linux-gnueabi 83``` 84 85### 安装Python3 86 87本项目要求安装Python 3.8及以上版本,本文档以Python 3.8为例。 88 891. 在bash中输入下列命令,查看python版本: 90 91 ```bash 92 python3 --version 93 ``` 94 95 如果不低于3.8,可以忽略第二步的重新安装,从第三步的设置开始。 96 972. 如果Python版本低于3.8,不建议直接升级,请按照如下步骤重新安装。 98 99 ```bash 100 sudo apt-get install python3.8 101 ``` 102 1033. 设置python和python3软链接为python3.8。 104 105 查看python3.8的位置: 106 107 ```bash 108 which python3.8 109 ``` 110 将python和python3切换为python3.8: 111 112 ```bash 113 sudo update-alternatives --install /usr/bin/python python /usr/bin/python3.8 1 114 # /usr/bin/python3.8 为上一步查看的python3.8的位置 115 sudo update-alternatives --install /usr/bin/python3 python3 /usr/bin/python3.8 1 116 # /usr/bin/python3.8 为上一步查看的python3.8的位置 117 ``` 118 1194. 安装并升级Python包管理工具(pip3),任选如下一种方式。 120 121 - **命令行方式:** 122 123 ```bash 124 sudo apt-get install python3-setuptools python3-pip -y 125 sudo pip3 install --upgrade pip 126 ``` 127 128 - **安装包方式:** 129 130 ```bash 131 curl https://bootstrap.pypa.io/get-pip.py -o get-pip.py 132 python get-pip.py 133 ``` 134 135### 安装ohos-build 136 137在安装ohos-build之前,请确保已安装Python 3.8及以上版本;否则,请[安装Python3](#安装python3)。 138 1391. 在bash中运行如下命令安装ohos-build: 140 141 ```bash 142 python3 -m pip install --user ohos-build 143 ``` 144 1452. 执行"hb -h",有打印以下信息即表示安装成功: 146 147 ```bash 148 usage: hb [-h] [-v] {build,set,env,clean} ... 149 150 OHOS Build System version 0.4.6 151 152 positional arguments: 153 {build,set,env,clean} 154 build Build source code 155 set OHOS build settings 156 env Show OHOS build env 157 clean Clean output 158 159 optional arguments: 160 -h, --help show this help message and exit 161 -v, --version show program's version number and exit 162 ``` 163 164### 安装Telink的编译工具链 165 166目前,社区中的RISCV32交叉编译工具链还未适配,可能会出现兼容性问题。 167因此,推荐使用来自[Telink官方网站](http://wiki.telink-semi.cn/wiki/IDE-and-Tools/BDT_for_TLSR9_Series_in_Linux/)的Telink RISC-V Linux Toolchain。 168 1691. 下载工具链 170 171 可以[点击下载该编译链工具](http://wiki.telink-semi.cn/tools_and_sdk/Tools/IDE/telink_riscv_linux_toolchain.zip),并解压到用户自行指定的位置。 172 或者,也可以使用下列命令下载并解压。 173 174 ```bash 175 wget http://wiki.telink-semi.cn/tools_and_sdk/Tools/IDE/telink_riscv_linux_toolchain.zip 176 unzip telink_riscv_linux_toolchain.zip 177 ``` 178 1792. 设置依赖项: 180 181 ```bash 182 sudo dpkg --add-architecture i386 183 sudo apt-get update 184 sudo apt-get install -y libc6:i386 libncurses5:i386 libstdc++6:i386 185 ``` 186 1873. 在~/.bashrc文件的末尾,根据该toolchain解压后所存放的路径,加入环境变量: 188 189 ```bash 190 # set environment path for TELINK toolchain 191 RISCV=telink_riscv_linux_toolchain/nds32le-elf-mculib-v5f 192 export PATH=~/$RISCV/bin:$PATH 193 ``` 194 1954. 保存后,重启bash或执行以下命令使环境变量生效: 196 197 ```bash 198 source ~/.bashrc 199 ``` 200 201## 获取源码 202 203在Linux环境下通过以下步骤获取OpenHarmony源码。 204 205本章节参考了OpenHarmoney文档《搭建轻量与小型系统》,[请点击详情查看详情](https://gitee.com/openharmony/docs/blob/master/zh-cn/device-dev/quick-start/quickstart-lite-env-setup.md)。 206 2071. 新建代码存放目录(用户可以自行指定为其他目录),如`openharmony`,并进入该目录: 208 209 ```bash 210 mkdir ~/openharmony 211 cd ~/openharmony 212 ``` 213 2142. Repo初始化,指定码云上面OpenHarmony的manifest仓库中所包含的git仓库: 215 216 ```bash 217 repo init -u https://gitee.com/openharmony/manifest --no-repo-verify 218 ``` 219 2203. 仓库初次同步,下载码云上所需的git仓库的代码。 221 222 ```bash 223 repo sync -c 224 ``` 225 226 这里下载的过程的耗时可能会很长,请耐心等待。 227 2284. 下载好代码后,下载大容量二进制文件。 229 230 ```bash 231 repo forall -c 'git lfs pull' 232 ``` 233 234## 确认目录结构 235 236在Linux环境下的源码的根目录下,可以查看SoC目录以及其他与Telink相关文件的目录结构。 237 238### SoC目录 239 240在device文件夹下,确保device/soc目录结构如下(截至2022年6月1日): 241 242```bash 243user:~/openharmony/device/soc$ tree -L 3 244. 245└── telink 246 ├── b91 # b91 SoC适配目录 247 │ ├── adapter # 外设驱动、BLE、文件系统适配 248 │ ├── b91m_ble_sdk # liteos b91 SDK适配 249 │ ├── BUILD.gn # GN构建脚本 250 │ ├── hcs # 设备描述文件 251 │ ├── hdf # HDF设备驱动框架目录 252 │ ├── Kconfig.liteos_m.defconfig.b91 # b91 Kconfig默认配置 253 │ ├── Kconfig.liteos_m.defconfig.series # series Kconfig默认配置 254 │ ├── Kconfig.liteos_m.series # series Kconfig配置项 255 │ ├── Kconfig.liteos_m.soc # SoC Kconfig配置项 256 │ ├── liteos.ld # 链接脚本 257 │ └── liteos_m # liteos_m 各模块实现 258 ├── BUILD.gn # GN构建脚本 259 ├── End User License Agreement.md # 终端用户证书协议 260 ├── figures # README插图文件夹 261 . ├── ... # 插图 262 │ └── ... # 插图 263 ├── Kconfig.liteos_m.defconfig # liteos_m Kconfig默认配置 264 ├── Kconfig.liteos_m.series # liteos_m series配置项 265 ├── Kconfig.liteos_m.soc # liteos_m SoC配置项 266 ├── LICENSE # 证书文件 267 ├── OAT.xml # 开源仓审查规则配置文件 268 ├── README.md # 英文版README 269 ├── README_zh.md # 中文版README 270 └── util # 工具项目录 271 └── util.gni # 固件生成脚本 272 273``` 274 275### Board目录 276 277在device文件夹下,确保device/board目录结构如下(截至2022年6月1日): 278 279```bash 280user:~/openharmony/device/board$ tree -L 3 281. 282└── telink 283 ├── b91_devkit # B91 Generic Starter Kit开发板配置目录 284 │ ├── b91_devkit_defconfig # B91 Generic Starter Kit Kconfig默认配置 285 │ ├── BUILD.gn # GN构建脚本 286 │ ├── Kconfig.liteos_m.board # Board liteos_m Kconfig配置项 287 │ ├── Kconfig.liteos_m.defconfig.board # Board liteos_m Kconfig默认配置 288 │ └── liteos_m # 构建脚本目录 289 ├── BUILD.gn # GN构建脚本 290 ├── drivers # 板级驱动存放目录 291 │ └── BUILD.gn # GN构建脚本 292 ├── hcs # hcs硬件描述配置目录 293 │ ├── b91_devkit.hcs # B91 Generic Starter Kit hcs硬件描述脚本 294 │ └── BUILD.gn # GN构建脚本 295 ├── figures # README插图文件夹 296 . ├── ... # 插图 297 │ └── ... # 插图 298 ├── Kconfig.liteos_m.boards # Board liteos_m Kconfig配置项 299 ├── Kconfig.liteos_m.defconfig.boards # Board liteos_m Kconfig默认配置 300 ├── LICENSE # 证书文件 301 ├── OAT.xml # 开源仓审查规则配置文件 302 ├── README.md # 英文版README 303 └── README_zh.md # 中文版README 304 305``` 306 307### Vendor目录 308 309在vendor文件夹下,确保vendor文件夹目录结构如下(截至2022年6月1日): 310 311```bash 312user:~/openharmony/vendor$ tree -L 3 313. 314└── telink 315 ├── ble_demo # BLE应用示例工程 316 │ ├── b91_gatt_sample # BLE示例代码 317 │ ├── BUILD.gn # GN构建脚本 318 │ ├── config.json # 子系统裁配置裁剪脚本 319 │ ├── hals # 产品参数配置 320 │ ├── hdf_config # HDF硬件描述配置 321 │ ├── kernel_configs # Kconfig配置输出 322 │ └── ohos.build # 子系统模块单 323 ├── led_demo # LED测试示例工程 324 │ ├── BUILD.gn # GN构建脚本 325 │ ├── config.json # 子系统裁配置裁剪脚本 326 │ ├── hals # 产品参数配置 327 │ ├── hdf_config # HDF硬件描述配置 328 │ ├── kernel_configs # Kconfig配置输出 329 │ ├── led_demo # LED示例代码 330 │ └── ohos.build # 子系统模块单 331 ├── xts_demo # XTS测试示例工程 332 │ ├── BUILD.gn # GN构建脚本 333 │ ├── config.json # 子系统裁配置裁剪脚本 334 │ ├── hals # 产品参数配置 335 │ ├── hdf_config # HDF硬件描述配置 336 │ ├── kernel_configs # Kconfig配置输出 337 │ └── ohos.build # 子系统模块单 338 ├── LICENSE # 证书文件 339 ├── OAT.xml # 开源仓审查规则配置文件 340 ├── README.md # 英文版README 341 └── README_zh.md # 中文版README 342``` 343 344## 编译工程 345 346进入Linux环境下源码根目录,可以开始编译工程。 347 3481. 设置工程根目录 349 350 在bash中输入以下命令,可以将当前源码根目录为工程根目录: 351 352 ```bash 353 hb set -root . 354 ``` 355 356 此时,会自动进入第二步中的产品选择界面。 357 358 > 如果hb set命令提示报错,请先执行以下命令去构建并安装ohos-build 359 360 ```bash 361 python3 -m pip install --user build/lite 362 ``` 363 3642. 选择样例产品: 365 366 产品选择界面如下: 367 368 ```bash 369 # OHOS Which product do you need? (Use arrow keys) 370 371 telink 372 >led_demo 373 xts_demo 374 ble_demo 375 ... 376 ``` 377 378 使用鼠标左击或者方向键`↑`和`↓`,可以选取需要编译的样例产品,按下回车键确定选项。 379 380 也可使用以下命令进行修改: 381 382 ```bash 383 hb set -p {PRODUCT_NAME} 384 ``` 385 386 `{PRODUCT_NAME}`为产品选择界面中列举出来的样例的名称,如`xts_demo`。 387 3883. 编译 389 390 后续修改了本样例产品中的文件,只需要执行以下命令进行编译,不需要再重复上述第一、二步去设置产品的根目录。 391 392 ```bash 393 hb build -f 394 ``` 395 396 生成的固件位于工程根目录下: 397 398 ```bash 399 out/{BOARD_NAME}/{PRODUCT_NAME}/bin/{PRODUCT_NAME}.bin 400 ``` 401 402 `{BOARD_NAME}`为主板名,为`b91_devkit`。 403 404## 烧录固件 405 406在Windows平台的环境下,烧录固件。 407 408### 烧录工具 409 410Burning and Debugging Tools(BDT)仅支持在Windows平台下安装和使用,其可执行安装程序为Telink BDT.exe。 411[点击下载BDT](http://wiki.telink-semi.cn/tools_and_sdk/Tools/BDT/BDT.zip) 412 413### 连接硬件 414 415请按照下面的图示进行硬件连接。图中的紫线表示USB线,其他两根线表示杜邦线。 416 417![硬件连接示意图](figures/flahsing_hw_connections_1.jpg) 418 419> 注意:务必采用默认的跳帽配置。 420 421下图是完成所有硬件连接后状态: 422 423![硬件连接实例](figures/flahsing_hw_connections_2.jpg) 424 425### 烧录 426 4271. 用USB线连接烧录器到电脑的USB口。 428 4292. 下载BDT烧录软件,解压到本地文件夹,双击可执行文件"Telink BDT.exe"。 430如果一切正常,可以看到如下的窗口显示,在系统标题栏中可以看到已被连接的烧录器的设备信息(见图中红色框)。 431 432 ![BDT正常启动后的界面](figures/bdt_connection.png) 433 4343. 点击工具栏中的"SWS"按钮,如果看到下图中的消息,则标明所有的硬件连接都没有问题。 435 436 ![按下SWS按钮后的界面显示](figures/bdt_connection_2.png) 437 4384. 设置Flash擦除的区域大小。点击工具栏中的"Setting"按钮,在弹出的“Setting"窗口中可以看到默认的Flash擦除的区域大小是512kB。 439 440 ![默认的Flash擦除的区域大小](figures/bdt_earse_size_512.png) 441 442 将Flash擦除的区域大小设置为“2040”,如下图所示: 443 444 ![改写Flash擦除的区域大小](figures/bdt_earse_size_2040.png) 445 446 > 注意:对于外挂2MB Flash的TLSR9518开发板,Flash最后的8kB空间预留用于保存重要的SoC信息,因此最多可以擦除2040kB的Flash区域。 447 4485. 点击工具栏中的"Erase"按钮,等待Flash擦除操作完成。 449 450 ![Flash擦除操作](figures/bdt_earse_done.png) 451 4526. 选择需要烧录的BIN文件。点击"File"菜单里面的"Open"子菜单,在弹出的文件选择对话框中选中需要烧录的BIN文件。选中后的BIN文件将显示在底部的状态栏中。 453 454 ![加载BIN文件](figures/bdt_file_open.png) 455 4567. 点击工具栏中"Download"按钮,等待Flash烧录完成。 457 458 ![Flash烧录操作](figures/bdt_flash_done.png) 459 460### 平台和驱动 461 462烧录工具不需要安装额外的驱动程序。 463 464如果烧录器插入电脑后,可以被Windows的设备管理器正确识别,但是烧录工具软件没有识别到,即在系统标题栏中看不到烧录器的设备信息。 465 466请检查电脑是否用了AMD平台的处理器,如果是的话,请换一台Intel平台处理器的电脑重新尝试。 467 468### 常见问题 469 470最常见的问题是:在点击工具栏中的"SWS"按钮后,出现下图中的错误信息。 471 472![按下SWS按钮后的错误信息](figures/bdt_sws_error.png) 473 474有两种主要原因。 475 476- 第一种原因是硬件连接不正确。 477 478请参照前面的说明仔细核对所有的[硬件连接](#连接硬件),确认没有遗漏的连接。 479 480- 在完全排除硬件连接问题之后,考虑第二种原因,即烧录器的固件版本太低。 481 482请按照下面步骤查看烧录器固件的版本。 483 4841. 点击Help菜单下的Upgrade子菜单。 485 4862. 在弹出的Upgrade EVK窗口中,点击"Read FW Version"按钮。在旁边的"Firmware Version"区域将会显示烧录器的固件版本号,例如下图。 487如果固件版本号低于V3.4,可以确认是由于固件版本太低导致了通讯错误。请继续下面的步骤去完成固件升级。 488 489 ![查看烧录器固件版本](figures/bdt_firmware_version.png) 490 4913. 点击窗口中的"Load..."按钮,在BDT工具所在目录下的config目录下的fw子目录找到最新的烧录器固件,如下图中的Firmware_v3.5.bin文件。 492 493 ![升级烧录器固件](figures/bdt_firmware_upgrade.png) 494 4954. 点击Upgrade按钮完成烧录器固件升级。 496 4975. 插拔烧录器的USB线,使烧录器重新上电。 498 499**提示:** 更多BDT的使用说明,请参考[Burning and Debugging Tools for all Series](http://wiki.telink-semi.cn/wiki/IDE-and-Tools/Burning-and-Debugging-Tools-for-all-Series/) 500 501## 相关仓库 502 503演示样例:[vendor_telink](https://gitee.com/openharmony/vendor_telink) 504 505B91开发板:[device_board_telink](https://gitee.com/openharmony/device_board_telink) 506