0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

移植鸿蒙系统到STM32L476RG_NUCLEO开发板的建议

电子工程师 来源:HarmonyOS社区 作者:HarmonyOS社区 2020-11-20 09:14 次阅读

https://gitee.com/walker2048/hmos_iot

移植鸿蒙的建议:
步骤一步来,别想一口吃成胖子,给自己定计划。多看源码以及编译日志,多想,多动手。源码既是文档,别想着百度或者谷歌能帮你直接解决问题。修改完代码后,完成了小部分功能的,也要及时提交GIT中。

1 ,首先肯定是创建厂商文件夹
首先按移植LiteOS教程里的说明,使用CubeMX工具生成makefile格式的项目(包含stm32l4xx标准hal库和ll库实现代码及makefile),并把项目文件复制到供应商/ st / stm32l4xx目录里。这就是2020- 11-06日 dbbaf5f这个提交所包含的内容。然后在该目录执行命令make> build.log,这样一是测试代码是否能正常编译,二是可以把stm官方提供的makefile实际执行指令信息存储到build.log文件里,方便以后修改gn系统的编译配置时做参考用

2,第二步配置编译环境及组件

根据以前的阅读makefile和嵌入式开发经验,应该先确定编译工具链。不同的硬件架构,需要的编译工具链并不一样,哪怕是一个最简单的helloworld,也没办法实现同一个bin文件,能在不同架构的硬件上直接运行。目前鸿蒙2.0配置好的两套编译工具(主要是gcc),并不能完成stm32的编译工作。

打开build / lite / toolchain /目录,复制gcc.gni文件的内容到arm_none_eabi_gcc.gni,进入第14行的ohos_kernel_type(内核类型)修改成liteos_m,进入15行的ohos_build_compiler_

prefix设置为正确的gcc工具设置为arm-none-eabi。其他内容暂时没动,然后根据其他开发板的设置,又复制了几遍配置,例如

构建/精简版/配置/板/ stm32l476rg_nucleo.gni

等等配置先抄一遍hi3861的,期间各种尝试使用编译命令蟒蛇build.py stm32l476rg_nucleo,直到不再提示找不到stm32l476rg_nucleo目标板,进入下一个确认工具链环节为止。这一环节中,比较重要的应该是build / lite / product / stm32l476rg_nucleo.json文件,该文件定义了目标板名称,编译工具链,内核等重要信息。

当编译命令提示arm-none-eabi-gcc不是OHOS的编译器时,我也没有楞一会儿。翻了生成目录下的各种配置也找不到对应的配置时,我就放弃找配置了。直接在VScode中插入搜索不包含OHOS编译器的大部分文件,最终在build / lite / config中。py的124行和158行找到了对应的判断语句,并增加了arm-none-eabi-gcc的判断语句。

随后测试编译时,又发现编译脚本会针对ohos_kernel_type进行各种优化和设置。没办法,就只能搜索ohos_kernel_type ==“ liteos_riscv”,指向文件一一修改。涉及到的文件也很多,详细请看gitee上的变更记录。

最终各组件的配置判断语句没问题了,能顺利进入到编译状态,出现类似以下信息了

===开始构建===

做完了648毫秒内从41个文件中取得39个目标

忍者:进入目录`/ mnt / out / stm32l476rg_nucleo'

[112分之1]交叉编译OBJ / APPLICATI组件/样品/ WiFi的IOT /应用/ demolink / helloworld.o

[2/112] AR libs / libdemolink.a

因此能出现[1/112]之类的,恭喜你,编译配置已经完成了80%了。期间还删除并容易出现问题的组件,例如wifi功能等等一堆组件

3,调整头文件配置
为了减少以后找文件找目录头疼,我在二进制目录新建了一个包括文件夹,链接疑似应该从厂商目录中提取出来的头文件放在该目录的hal目录下,从而难以解决的头文件错误组件去掉,不编译对应组件。最终编译命令都顺利通过了,只差最后一步生成小精灵和箱文件了。

4,根据原厂生成文件和修改编译调整细节
重头戏的英文此文件生成/精简版/工具链/ arm_none_eabi_gcc.gni,查看原厂makefile的build.log文件,可以裁剪编译过程为.c文件=>。o文件,然后.S文件=>。o文件,然后将所有的.o文件以及STM32L476RGTx_FLASH.ld文件一起链接成elf文件。最后再由elf文件生成bin和hex。

多次尝试修改后,最终调整为以下内容

template(“ gcc_toolchain”){

工具链(target_name){

断言(已定义(invoker.cc),“ gcc工具链必须指定一个“ cc ”值“)

断言(已定义(invoker.cxx),“ gcc工具链必须指定一个“ cxx ”值“)

断言(已定义(invoker.ld),“ gcc工具链必须指定一个“ ld ”值“)

断言(已定义(invoker.ar),“ gcc工具链必须指定一个“ ar ”值“)

断言(定义(invoker.as),““工具链必须指定一个” as “值”)

断言(定义(invoker.cp),““工具链必须指定一个“ cp ”值”)

ar = invoker.ar

as =调用者

cc = invoker.cc

cxx = invoker.cxx

ld = invoker.ld

cp = invoker.cp

need_strip =否

if(defined(invoker.strip)){

剥离= invoker.strip

need_strip = true

}

如果(defined(invoker.extra_

ldflags)&&invoker.extra_ldflags!=“”){

extra_ldflags =“”

}其他{

extra_ldflags =“”

}

工具(“ cc”){

命令=“ $ cc -c {{cflags}} {{defines}} {{include_dirs}} {{cflags_c}}” +

#“ -MMD -MP -MF'{{source_out_dir}} / {{source_name_part}}。d'” +

#“ -Wa,-a,-ad,-alms = {{source_out_dir}} / {{source_name_part}}。lst” +

“ {{source}} -o {{output}}”

depsformat =“ gcc”

description =“跨编译器{{output}}”

输出= [

“ {{source_out_dir}} / {{source_name_part}}。o”,

]

}

工具(“ cxx”){

depfile =“ {{output}}。d”

命令=“ $ cxx -c {{cflags}} {{defines}} {{include_dirs}} {{cflags_c}}” +

#“ -MMD -MP -MF'{{source_out_dir}} / {{source_name_part}}。d'” +

#“ -Wa,-a,-ad,-alms = {{source_out_dir}} / {{source_name_part}}。lst” +

“ {{source}} -o {{output}}”

depsformat =“ gcc”

description =“ CXX {{output}}”

输出= [

“ {{source_out_dir}} / {{target_output_name}}。{{source_name_part}}。o”,

]

}

工具(“ asm”){

depfile =“ {{output}}。d”

command =“ $ as -c {{cflags}} {{defines}} {{include_dirs}} {{asmflags}} {{source}} {{cflags_c}}” +

“ -o {{输出}}”

depsformat =“ gcc”

description =“跨编译器{{output}}”

输出= [

“ {{source_out_dir}} / {{source_name_part}}。o”

]

}

工具(“链接”){

outfile =“ {{output_dir}} / {{target_output_name}} {{output_extension}}”

rspfile =“ {{output}}。rsp”

rspfile_content =“ {{inputs}}”

命令=“ $ ar cr {{输出}} @ ” $ rspfile “”

description =“ AR {{output}}”

输出= [

超越

]

default_output_dir =“ {{root_out_dir}} / libs”

default_output_extension =“ .a”

output_prefix =“ lib”

}

工具(“链接”){

outfile =“ {{output_dir}} / bin / {{target_output_name}}。elf”

rspfile =“ $ outfile.rsp”

command =“ $ ld {{inputs}} {{ldflags}} $ extra_ldflags -specs = nano.specs” +

#在供应商路径中设置ld文件补丁

“ -lc -lm -lnosys {{libs}} -Wl,-Map = {{target_output_name}}。map,-cref” +

“ -Wl,-gc-sections -o $ outfile”

if(need_strip){

命令+ =“ && $ cp -O二进制-S $ outfile {{output_dir}} / bin / {{target_output_name}}。bin”

}

description =“ LINK $ outfile”

default_output_dir =“ {{root_out_dir}}”

rspfile_content =“ {{inputs}}”

输出= [

超越

]

}

工具(“邮票”){

如果(host_os ==“ win”){

命令=“ cmd / c类型nul> ” {{输出}} “”

}其他{

命令=“ / usr / bin / touch {{输出}}”

}

description =“ STAMP {{output}}”

}

工具(“复制”){

命令=“ $ cp -O二进制-S {{源}} {{输出}}。bin && echo $ strip”

description =“ COPY {{源}} {{输出}}”

}

}

同时在stm32l4xx / Src / BUILD.gn文件中添加ldflags,实现ld文件在厂商文件内部设置。

ldflags = [

“ -T”,

“ ../../vendor/st/stm32l4xx/STM32L476RGTx_FLASH.ld”

]

最终,顺利生成了一个elf文件,bin文件以及hex文件。其实gn配置相对来说,命令行的提示,以及配置的定位性都是相当不错的。还是建议大家多动手,多看,多想。

责任编辑:xj

原文标题:移植鸿蒙系统到STM32L476RG_NUCLEO开发板的一点小经验

文章出处:【微信公众号:HarmonyOS社区】欢迎添加关注!文章转载请注明出处。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 移植
    +关注

    关注

    1

    文章

    377

    浏览量

    28107
  • 开发板
    +关注

    关注

    25

    文章

    4942

    浏览量

    97174
  • 鸿蒙系统
    +关注

    关注

    183

    文章

    2634

    浏览量

    66204

原文标题:移植鸿蒙系统到STM32L476RG_NUCLEO开发板的一点小经验

文章出处:【微信号:HarmonyOS_Community,微信公众号:电子发烧友开源社区】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    如何在开源鸿蒙OpenHarmony开启SELinux模式?RK3566鸿蒙开发板演示

    本文介绍开源鸿蒙OpenHarmony系统下,开启/关闭SELinux权限的方法,触觉智能Purple Pi OH鸿蒙开发板演示,已适配全新OpenHarmony5.0 Release
    的头像 发表于 11-18 19:03 147次阅读
    如何在开源<b class='flag-5'>鸿蒙</b>OpenHarmony开启SELinux模式?RK3566<b class='flag-5'>鸿蒙</b><b class='flag-5'>开发板</b>演示

    正点原子的stm32开发板能用stlink吗

    开发板概述 正点原子提供的STM32开发板涵盖了从基础高级的多种型号,包括但不限于STM32F103、
    的头像 发表于 11-13 09:21 279次阅读

    基于机智云移植STM32L496G代码移植

    前言最近我拿到了STM32L496AGMCU,发现其扩展版可以连接ESP-01S。我想尝试将开发板连接到我们的机智云上,并根据机智云提供的文档进行程序移植STM32CubeMX
    的头像 发表于 09-20 08:05 306次阅读
    基于机智云<b class='flag-5'>移植</b><b class='flag-5'>STM32L</b>496G代码<b class='flag-5'>移植</b>

    鸿蒙OpenHarmony南向/北向快速开发教程-迅为RK3568开发板

    大家期待已久的迅为RK3568开发板终于迎来了鸿蒙4.1系统的强势支持!想知道如何实现快速开发学习吗?跟着我们一起来探索吧! 迅为RK3568开发板
    发表于 07-23 10:44

    使用stm32 NUCLEO开发板时,更多的用哪个扩展口?

    你在使用stm32 NUCLEO开发板时,更多的用哪个扩展口?
    发表于 05-13 06:34

    请问STM32和STM8的STLINK通用吗?

    我用NUCLEO-L476RG开发板上的STLINK连接血糖仪上的单片机老是连接不上
    发表于 05-11 09:06

    stm32L476RG RTC的秒中断如何使用?

    stm32L476RG RTC的秒中断如何使用
    发表于 04-26 08:24

    stm32l476移植程序后,不执行的原因?怎么解决?

    stm32l476移植程序后,不执行。
    发表于 03-28 08:28

    Nucleo L476RG和IPM15B 3Sh连接失败的原因?

    使用的是Nucleo L476RG开发板和IPM15B 3Sh功率,正常进行接线后,motor profiler软件会提示下载固件,正常下载完成后,输入电机的极对数电压等参数,点连接
    发表于 03-26 07:46

    如何将STM32L476RG的信息传输给X-NUCLEO-nfc并进行手机读取?

    如何将STM32L476RG的信息传输给X-NUCLEO-nfc并进行手机读取
    发表于 03-20 07:02

    移植libmodbus库米尔-全志T113-i开发板

    测试开发板在工业领域的应用,modbus作为工业领域的一个重要协议,那好就移植libmodbus库。
    的头像 发表于 03-05 22:37 2264次阅读
    <b class='flag-5'>移植</b>libmodbus库<b class='flag-5'>到</b>米尔-全志T113-i<b class='flag-5'>开发板</b>

    鸿蒙】标准系统移植指南

    标准系统移植指南 本文描述了移植一块开发板的通用步骤,和具体芯片相关的详细移植过程无法在此一一列举。后续社区还会陆续发布
    的头像 发表于 02-27 14:36 836次阅读
    【<b class='flag-5'>鸿蒙</b>】标准<b class='flag-5'>系统</b><b class='flag-5'>移植</b>指南

    ELF 1技术贴|如何将Python3.6.9移植开发板

    如何进行交叉编译并移植ELF1开发板上。在网址:https://www.python.org/ftp/python/下载Python-3.6.9.tar.xz压缩
    的头像 发表于 02-22 14:06 403次阅读
    ELF 1技术贴|如何将Python3.6.9<b class='flag-5'>移植</b><b class='flag-5'>到</b><b class='flag-5'>开发板</b>上

    盘点那些硬件+项目学习套件:Hi3861鸿蒙开发板及入门常见问题解答

    、源码、视频课程,可以进行单片机入门、电机控制基础、总线通讯-协议学习。Hi3861鸿蒙+STM32单片机的协作开发:Hi3861鸿蒙开发板
    发表于 02-01 16:55

    鸿蒙设备-开发板基础学习(BearPi-HM Micro)

    + OpenHarmony小型系统”。BearPi-HM Micro是一款使用STM32MP157处理器的鸿蒙开发板,目前提供使用LiteOS-A操作
    发表于 01-08 21:54