打印
[其他]

移植 TencentOS 到 PLUS-F5270

[复制链接]
7475|6
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
nawu|  楼主 | 2023-3-30 19:01 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
在 Linux 使用 openocd 链接 PLUS-F5270
如果需要使用 openocd 链接 STAR-MC1,需要打上这个 pr

diff --git a/src/target/cortex_m.c b/src/target/cortex_m.c
index aeaeb1829..1bb37797a 100644
--- a/src/target/cortex_m.c
+++ b/src/target/cortex_m.c
@@ -91,6 +91,12 @@ static const struct cortex_m_part_info cortex_m_parts[] = {
         .arch = ARM_ARCH_V8M,
         .flags = CORTEX_M_F_HAS_FPV5,
     },
+    {
+        .partno = START_MC1_PARTNO,
+        .name = "START-MC1",
+        .arch = ARM_ARCH_V8M,
+        .flags = CORTEX_M_F_HAS_FPV5,
+    },
     {
         .partno = CORTEX_M35P_PARTNO,
         .name = "Cortex-M35P",
diff --git a/src/target/cortex_m.h b/src/target/cortex_m.h
index 69368a919..89dfd6669 100644
--- a/src/target/cortex_m.h
+++ b/src/target/cortex_m.h
@@ -44,6 +44,7 @@ enum cortex_m_partno {
     CORTEX_M0P_PARTNO  = 0xC60,
     CORTEX_M23_PARTNO  = 0xD20,
     CORTEX_M33_PARTNO  = 0xD21,
+    START_MC1_PARTNO   = 0x132,
     CORTEX_M35P_PARTNO = 0xD31,
     CORTEX_M55_PARTNO  = 0xD22,
};




如果还要通过 openocd 下载程序到 flash, 还需要再打下 patch:

diff --git a/src/flash/nor/stm32f1x.c b/src/flash/nor/stm32f1x.c
index 455a06a9b..8721c1278 100644
--- a/src/flash/nor/stm32f1x.c
+++ b/src/flash/nor/stm32f1x.c
@@ -761,6 +761,7 @@ static int stm32x_get_property_addr(struct target *target, struct stm32x_propert
         addr->flash_size = 0x1FFFF7E0;
         return ERROR_OK;
     case CORTEX_M_PARTNO_INVALID:
+    case START_MC1_PARTNO:
         /* Check for GD32VF103 with RISC-V CPU */
         if (strcmp(target_type_name(target), "riscv") == 0
                 && target_address_bits(target) == 32) {
@@ -771,6 +772,12 @@ static int stm32x_get_property_addr(struct target *target, struct stm32x_propert
             addr->flash_size = 0x1FFFF7E0;
             return ERROR_OK;
         }
+        else
+        {
+            addr->device_id = 0x40007080;
+            addr->flash_size = 0x1FFFE920;
+            return ERROR_OK;
+        }
         /* fallthrough */
     default:
         LOG_ERROR("Cannot identify target as a stm32x");
@@ -869,6 +876,7 @@ static int stm32x_probe(struct flash_bank *bank)
         stm32x_info->can_load_options = true;
         break;
     case 0x410: /* stm32f1x medium-density */
+    case 0x800: /* mm32f527x medium-density */
         page_size = 1024;
         stm32x_info->ppage_size = 4;
         max_flash_size_in_kb = 128;
@@ -882,6 +890,7 @@ static int stm32x_probe(struct flash_bank *bank)
            because of unexpected active hardware watchog. */
         switch (rev_id) {
         case 0x1303: /* gd32f1x0 */
+        case 0x4d4d: /* mm32f527x */
             stm32x_info->user_data_offset = 16;
             stm32x_info->option_offset = 6;
             max_flash_size_in_kb = 64;




还有两个 cfg 配置文件板级的 mmplus.cfg:

#adapter list

source [find interface/jlink.cfg]

transport select swd

adapter speed 100

#jink config

source [find mm32f5270.cfg]

proc mmd { pos } {
    if { $pos == 0 } {
        reset;
        halt;
        flash write_image erase TencentOS_tiny.bin 0x8000000;
        reset;
        echo "mmd down firm 2 internal flash success"
    } else {
        echo "mmd down firm 2 spi flash"
    }
}



和平台级的 mm32f5270.cfg:

source [find target/swj-dp.tcl]
#source [find mem_helper.tcl]

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

set FLASH_SIZE 0x40000

# Allow overriding the Flash bank size
if { [info exists FLASH_SIZE] } {
    set _FLASH_SIZE $FLASH_SIZE
} else {
    # autodetect size
    set _FLASH_SIZE 0
}

# ONLY use ENDIAN with targets that can change it.
if { [info exists ENDIAN] } {
set _ENDIAN $ENDIAN
} else {
set _ENDIAN little
}

if { [info exists CPUTAPID ] } {
set _CPUTAPID $CPUTAPID
} else {
#set _CPUTAPID 0x1be12aeb
set _CPUTAPID 0x1aeb0015
}

set _TARGETNAME $_CHIPNAME.cpu

#swj_newdap $_CHIPNAME cpu -irlen 5 -ircapture 0x1 -irmask 0xf -ignore-version -expected-id $_CPUTAPID
swj_newdap $_CHIPNAME cpu -irlen 5 -ircapture 0x1 -irmask 0xf -expected-id $_CPUTAPID
dap create $_CHIPNAME.dap -chain-position $_TARGETNAME
target create $_TARGETNAME cortex_m -dap $_CHIPNAME.dap -ap-num 0

# 定义一块内存区域用来烧录程序到 flash 临时使用
# 定义一块内存区域的起始地址,在 MMU 未开启时使用
$_TARGETNAME configure -work-area-phys 0x30000000 -work-area-size 0x4000

set _FLASHNAME $_CHIPNAME.flash
flash bank $_FLASHNAME stm32f1x 0x08000000 $_FLASH_SIZE 0 0 $_TARGETNAME
#flash bank $_FLASHNAME mm32f527x 0x08000000 $_FLASH_SIZE 0 0 $_TARGETNAME

proc mm32f5270_reset_init {} {
    # 配置 PLL 时钟
    # mww
}

$_TARGETNAME configure -event reset-init { mm32f5270_reset_init }

cortex_m reset_config sysresetreq

#$CHIPNAME init



至此就可以正常连接 STAR-MC1 了

移植 TOS 到 PLUS-F5270
花费了好几天的时间完成了 TOS 在 PLUS-F5270 上的部署,移植过程中发现在执行到函数port_sched_start的LDMFD SP!, {R4 - R11}这句话的时候就会进入到 HardFault.经过多番排查,定位到是ARMv8-M指令集的stack limit功能导致的。该功能具体描述是:

官方的代码在 Reset_Handler 中赋值了 msplim 和 psplim 寄存器,所以在线程调度的时候,当使用线程栈指针时,超过了 stack limit 导致系统异常。其中 psplim 是检查 thread mode 的栈指针即 psp,msplim 检查的是 handler mode 的栈指针即 msp。特别地,在异常(handler mode)中一直使用的是 msp,异常一般被当作内核态,在 thread mode 时候,会根据CONTROL.nPRIV determines whether execution in Thread mode is unprivileged确定使用的是特权还是非特权。特权使用的是 msp, 非特权则是 psp 指针。

ldr      r0, =__STACK_LIMIT
msr      msplim, r0
msr      psplim, r0


为了避免这个问题可以有多种方案:

关闭 stack limit 检查,CCR, Configuration and Control Register寄存器的 bit 10
修改该 bit 位为 1

在线程调度过程中更新 psplim,目前我看 RT-Thread 使用的是这种方法,但是这个 psplim 实际一直是 0(所以也可以认为并没有使用硬件进行 stack limit 检查).
直接设置 msplim 和 psplim 为 0
解决这个问题后,就可以正常运行 TOS 了。

————————————————
版权声明:本文为CSDN博主「极术社区」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_47569031/article/details/127383361

使用特权

评论回复
沙发
abotomson| | 2023-4-13 20:28 | 只看该作者
源码地址在这里:https://github.com/Tencent/TencentOS-tiny。

使用特权

评论回复
板凳
mattlincoln| | 2023-4-13 20:52 | 只看该作者
轻量级物联网实时操作系统 TencentOS tiny。  

使用特权

评论回复
地板
hilahope| | 2023-4-13 21:53 | 只看该作者
学习任何一个RTOS,本质是没有什么太大的区别的

使用特权

评论回复
5
wilhelmina2| | 2023-4-13 21:59 | 只看该作者
TencentOS 支持很多种类的芯片了。

使用特权

评论回复
6
dspmana| | 2023-4-13 22:17 | 只看该作者
TencentOS tiny 是腾讯面向物联网领域开发的实时操作系统  

使用特权

评论回复
7
zerorobert| | 2023-4-13 22:46 | 只看该作者
tencentos tiny 目前是开源的  

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

73

主题

3308

帖子

3

粉丝