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

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

3天内不再提示

记录Red Lite Env项目的基础搭建过程及碰到的问题

冬至子 来源:兆易创新GD32 MCU 作者:Red 2022-09-30 14:52 次阅读

Linux 下如何使用对 GD32F310G START 进行在线调试以及程序下载

需要使用的关键工具是,开源的调试器 openocd, 涉及到有两个配置文件,分别是 target 的配置文件 gd32f3x.cfg:

# script for stm32f3x family

#
# stm32 devices support both JTAG and SWD transports.
#
source [find target/swj-dp.tcl]
source [find mem_helper.tcl]

if { [info exists CHIPNAME] } {
   set _CHIPNAME $CHIPNAME
} else {
   set _CHIPNAME stm32f3x
}

set _ENDIAN little

# Work-area is a space in RAM used for flash programming
# By default use 16kB
if { [info exists WORKAREASIZE] } {
   set _WORKAREASIZE $WORKAREASIZE
} else {
   set _WORKAREASIZE 0x4000
}

# JTAG speed should be <= F_CPU/6. F_CPU after reset is 8MHz, so use F_JTAG = 1MHz
#
# Since we may be running of an RC oscilator, we crank down the speed a
# bit more to be on the safe side. Perhaps superstition, but if are
# running off a crystal, we can run closer to the limit. Note
# that there can be a pretty wide band where things are more or less stable.
adapter speed 1000

adapter srst delay 100
if {[using_jtag]} {
 jtag_ntrst_delay 100
}

#jtag scan chain
if { [info exists CPUTAPID] } {
   set _CPUTAPID $CPUTAPID
} else {
   if { [using_jtag] } {
      # See STM Document RM0316
      # Section 29.6.3 - corresponds to Cortex-M4 r0p1
      set _CPUTAPID 0x4ba00477
   } {
      set _CPUTAPID 0x2ba01477
   }
}

swj_newdap $_CHIPNAME cpu -irlen 4 -ircapture 0x1 -irmask 0xf -expected-id $_CPUTAPID
dap create $_CHIPNAME.dap -chain-position $_CHIPNAME.cpu

if {[using_jtag]} {
   jtag newtap $_CHIPNAME bs -irlen 5
}

set _TARGETNAME $_CHIPNAME.cpu
target create $_TARGETNAME cortex_m -endian $_ENDIAN -dap $_CHIPNAME.dap

$_TARGETNAME configure -work-area-phys 0x20000000 -work-area-size $_WORKAREASIZE -work-area-backup 0

set _FLASHNAME $_CHIPNAME.flash
flash bank $_FLASHNAME stm32f1x 0 0 0 0 $_TARGETNAME

reset_config srst_nogate

if {![using_hla]} {
   # if srst is not fitted use SYSRESETREQ to
   # perform a soft reset
   cortex_m reset_config sysresetreq
}

proc stm32f3x_default_reset_start {} {
    # Reset clock is HSI (8 MHz)
    adapter speed 1000
}

proc stm32f3x_default_examine_end {} {
    # Enable debug during low power modes (uses more power)
    mmw 0xe0042004 0x00000007 0 ;# DBGMCU_CR |= DBG_STANDBY | DBG_STOP | DBG_SLEEP

    # Stop watchdog counters during halt
    mmw 0xe0042008 0x00001800 0 ;# DBGMCU_APB1_FZ |= DBG_IWDG_STOP | DBG_WWDG_STOP
}

proc stm32f3x_default_reset_init {} {
    # Configure PLL to boost clock to HSI x 8 (64 MHz)
    mww 0x40021004 0x00380400   ;# RCC_CFGR = PLLMUL[3:1] | PPRE1[2]
    mmw 0x40021000 0x01000000 0 ;# RCC_CR |= PLLON
    mww 0x40022000 0x00000012   ;# FLASH_ACR = PRFTBE | LATENCY[1]
    sleep 10                    ;# Wait for PLL to lock
    mmw 0x40021004 0x00000002 0 ;# RCC_CFGR |= SW[1]

    # Boost JTAG frequency
    adapter speed 8000
}

# Default hooks
$_TARGETNAME configure -event examine-end { stm32f3x_default_examine_end }
$_TARGETNAME configure -event reset-start { stm32f3x_default_reset_start }
$_TARGETNAME configure -event reset-init { stm32f3x_default_reset_init }

$_TARGETNAME configure -event trace-config {
    # Set TRACE_IOEN; TRACE_MODE is set to async; when using sync
    # change this value accordingly to configure trace pins
    # assignment
    mmw 0xe0042004 0x00000020 0
}

board 的配置文件 gd32f3start.cfg

# sudo openocd -f interface/cmsis-dap.cfg -c "transport select swd" -c "set CPUTAPID 0" -f target/gd32f3x.cfg
#
source [find interface/cmsis-dap.cfg]
transport select swd

set CPUTAPID 0
set WORKAREASIZE 0x2000
source [find target/gd32f3x.cfg]

proc gdd { pos } {
    if { $pos == 0 } {
        reset;
        halt;
        flash write_image erase TencentOS_tiny.bin 0x8000000;
        reset;
        echo "stm down firm 2 internal flash success"
    } else {
        echo "invalid gdd down to others"
    }
}

分别将上述配置文件放到 openocd 的安装目录,大概是这样的:

▸ tree -L  1 /usr/share/openocd/scripts/
/usr/share/openocd/scripts/
├── bitsbytes.tcl
├── board  ==> 放 gd32f3start.cfg 配置文件
├── chip
├── cpld
├── cpu
├── fpga
├── interface
├── mem_helper.tcl
├── memory.tcl
├── mmr_helpers.tcl
├── target  ==> 放 gd32f3x.cfg 配置文件
├── test
└── tools

9 directories, 4 files

连接开发板的命令是 openocd -f board/gd32f3start.cfg, 如果一切顺利你会看到这样的信息

poYBAGM2kcqAEdC3AAFizhsdUCU126.png

接下去可以:

使用 arm-none-eabi-gdb 连接本机的 3333 端口远程调试开发板

使用 telnet 链接本机的 4444 端口进行程序下载调试

效果大概是这样的:

poYBAGM2kd-ADKuWAALBWkcGRto979.png

环境搭建好了之后,就可以开发愉快的开发了。

移植 Tencent OS 到 GD32F310G START

移植系统比较快的方法是:

参考一个架构类似的处理器的工程,然后复制修改替换,保证编译通过

阅读整个系统的代码走向,点灯调试

逐步优化代码,最后可以提交 療 到上游

此处具体的移植步骤我就不详细记录了,因为网上有丰富的系统移植的教程,都是大同小异的。我在此仅仅展示下我移植过程中的一些提交记录:

poYBAGM2kfKAY90hAADaNUhMX4Y832.png

特别地,我将 TencentOS Tiny 的 shell 组件添加进来了,所以效果是这样的:

pYYBAGM2kgSAVct9AAEVqXipy-w744.png




审核编辑:刘清

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

    关注

    134

    文章

    8651

    浏览量

    361777
  • Linux
    +关注

    关注

    87

    文章

    10990

    浏览量

    206733
  • JTAG
    +关注

    关注

    6

    文章

    383

    浏览量

    71150
  • 调试器
    +关注

    关注

    1

    文章

    288

    浏览量

    23405
收藏 人收藏

    评论

    相关推荐

    硬件测试服务项目的重要性和作用

    服务项目的定义与重要性 硬件测试服务项目是对硬件设备(如结构、PCBA、关键部件等)进行差错检查的过程,旨在保证产品的质量和性能。在硬件产品开发过程中,测试是不可或缺的一环,它能够帮助
    的头像 发表于 03-28 09:54 124次阅读
    硬件测试服务<b class='flag-5'>项目的</b>重要性和作用

    OpenHarmony 移植:build lite 编译构建过程

    的?解决了这些疑惑,会对 build lite 编译构建过程有个更深入的理解。 1、产品解决方案代码是如何被调用编译的 在文件 buildliteBUILD.gn 配置文件中的构建目标 //build/lite
    的头像 发表于 02-19 16:19 553次阅读

    MES系统项目的正确实施

    电子发烧友网站提供《MES系统项目的正确实施.docx》资料免费下载
    发表于 01-31 09:24 0次下载

    记录RocketMQ在centos7上的安装过程

    本文记录RocketMQ在centos7上的安装过程,没有技术的探讨,仅仅是安装记录,以作备忘。
    的头像 发表于 01-02 11:41 265次阅读
    <b class='flag-5'>记录</b>RocketMQ在centos7上的安装<b class='flag-5'>过程</b>

    springcloud项目搭建及部署

    如何搭建并部署Spring Cloud项目。 一、环境准备 在开始之前,我们需要准备以下环境: Java开发环境:确保已经安装了Java SE Development Kit(JDK)。 Maven
    的头像 发表于 12-03 15:52 546次阅读

    Cadence本地库搭建从0到1的过程

    本文将主要介绍Cadence本地库搭建从0到1的过程,并提供搭建过程中所需要的安装软件。搭建Cadence本地库的
    的头像 发表于 11-20 17:21 1195次阅读
    Cadence本地库<b class='flag-5'>搭建</b>从0到1的<b class='flag-5'>过程</b>

    【涂鸦T2-U开发板试用体验】记录搭建开发平台过程

    忙了一天终于搭建环境成功了,安装了虚拟机和vscode,按照教程一步一步,其中也碰到了很多问题,通过不断尝试和探索,总算是编译成功了。 首先需要安装虚拟机环境,我的电脑一开始并没有,下载vmware
    发表于 11-19 17:30

    四大LED相关项目的建设明显提速

    三季度起,企业对LED相关项目的建设明显提速!
    的头像 发表于 11-16 13:54 348次阅读

    在Linux中使用RT-Thread Env工具的简明指南

    Env 是 RT-Thread 对源码进行配置和裁剪、生成工程的工具,然而文档中的配置过程主要针对 Windows 系统,并没有对 Linux 系统的配置进行详细的介绍,这里简要介绍其在 Linux 下的配置与使用方法。
    的头像 发表于 09-26 14:26 729次阅读
    在Linux中使用RT-Thread <b class='flag-5'>Env</b>工具的简明指南

    9亿元!豪恩汽电行车记录系统获项目定点

    豪恩汽电在电动汽车公司深入汽车智能驾驶感知系统领域数年,本次来信指出,客户对运行记录系统产品的指定,标志是客户公司项目的研发,生产,制造;充分体现质量管理等方面的认可,豪恩在汽车电动汽车智能驾驶感知系统领域的综合实力有利于提供混合汽车电器的市场占有率和知名度
    的头像 发表于 09-21 14:38 409次阅读

    HarmonyOS/OpenHarmony应用开发-DevEco Studio新建项目的整体说明

    与开发路径等的认知。 2区是代码开发与修改区,是开发者主要的工作区域。 3.是效果展示区,包括远程模拟器、远程真机、本地模拟器等方式。 4.是项目运行区域,查看项目运行的过程。 5.是IDE菜单栏区
    发表于 09-15 16:51

    从零使用env工具生成gd32f450工程

    下载rtthread源码,进入文件夹bsp/gd32/arm/gd32450z-eval下,使用env工具,将程序打包。
    的头像 发表于 08-15 15:20 707次阅读
    从零使用<b class='flag-5'>env</b>工具生成gd32f450工程

    keil5+Env将变量定义到SDRAM中的过程

    其实要把特别大的变量(数组)定义到SDRAM中步骤很简单,但这个过程却困扰了我好久,此篇文章就作为个人学习笔记参考参考吧。
    的头像 发表于 08-02 14:39 1319次阅读
    keil5+<b class='flag-5'>Env</b>将变量定义到SDRAM中的<b class='flag-5'>过程</b>

    Node RED互联网RGB LED开源项目

    电子发烧友网站提供《Node RED互联网RGB LED开源项目.zip》资料免费下载
    发表于 07-12 11:05 0次下载
    Node <b class='flag-5'>RED</b>互联网RGB LED开源<b class='flag-5'>项目</b>

    S32和PowerPc artitechure是否支持项目的C++实现?

    我想为 PowerPc MPC577C 实现 C++ 源代码。我更喜欢 freeGCC 作为编译器。我在实施过程中遇到了问题。我选择 C++11 作为版本。我想知道 S32 和 PowerPc artitechure 是否支持项目的 C++ 实现?
    发表于 05-12 06:15