跳转至内容
  • 版块
  • 最新
  • 标签
  • 热门
折叠
品牌标识

YunTu Forum

YTMicro.com
  1. 主页
  2. Discussion & Question
  3. YTM32B1H系列
  4. MCAL环境下,32B1H固件升级加密问题

MCAL环境下,32B1H固件升级加密问题

已定时 已固定 已锁定 已移动 YTM32B1H系列
14 帖子 4 发布者 171 浏览
  • 从旧到新
  • 从新到旧
  • 最多赞同
登录后回复
此主题已被删除。只有拥有主题管理权限的用户可以查看。
  • DigaD 离线
    DigaD 离线
    Diga
    写于 最后由 编辑
    #4

    https://forum.ytmicro.com/topic/90/ytm32b1mc-安全启动demo?_=1737338340238

    yxydoctorY 1 条回复 最后回复
    0
    • yxydoctorY 离线
      yxydoctorY 离线
      yxydoctor
      在 回复了 Diga 最后由 编辑
      #5

      Diga 您好,这篇文档拜读了,还是有疑问(32B1H+MCAL)
      问题1:似乎只涉及到安全boot和加密解密,没有涉及串口或CAN口做固件下载;
      问题2:所涉及到的HCU等模块配置,在MCAL环境下还好配置吧;

      1 条回复 最后回复
      0
      • DigaD 离线
        DigaD 离线
        Diga
        写于 最后由 编辑
        #6

        流程可以是这样的,ROM 区的安全引导+用户自己的 bootloader
        MCAL 的 crypto 模块就是加密的

        yxydoctorY 1 条回复 最后回复
        0
        • yxydoctorY 离线
          yxydoctorY 离线
          yxydoctor
          在 回复了 Diga 最后由 编辑
          #7

          Diga 明白了,还是得自行编写两段代码做跳转通过YTC做加密。
          还奇怪为什么大部分Cortex都有BOOT引脚,而32B1H没有,原来是直接放弃这种方案了

          FrankieF 1 条回复 最后回复
          0
          • FrankieF 离线
            FrankieF 离线
            Frankie YunTu
            在 回复了 yxydoctor 最后由 编辑
            #8

            yxydoctor 汽车MCU都没有吧

            yxydoctorY 1 条回复 最后回复
            0
            • yxydoctorY 离线
              yxydoctorY 离线
              yxydoctor
              在 回复了 Frankie 最后由 编辑
              #9

              Frankie 谢谢专家提醒。设定这样一种串口升级方案(32B1H+MCAL),不知是否可行
              BOOT固件:增加一个IO用于开机模式设置。 如果一定时间内(如100ms),BOOT引脚拉低,则不跳转,通过串口接收上位机新固件,接收完毕后再跳转,否则直接跳转。

              用户APP固件:不涉及跟串口升级有关的任何代码。

              但不论是BOOT固件还是APP固件,都会涉及跟Linker文件有关的修改重新配置,这点是有难度的。

              想请教一下:官方是否有这方面的例程或应用笔记,

              1 条回复 最后回复
              0
              • FrankieF 离线
                FrankieF 离线
                Frankie YunTu
                写于 最后由 编辑
                #10

                根据你们项目的实际情况,自行决定升级方案。我们提供了CAN UDS Bootloader的demo。https://yt-micro.feishu.cn/wiki/Vu7WwWjLwi8AT4kkeHxctEEYnjh?fromScene=spaceOverview

                yxydoctorY 1 条回复 最后回复
                0
                • yxydoctorY 离线
                  yxydoctorY 离线
                  yxydoctor
                  在 回复了 Frankie 最后由 编辑
                  #11

                  Frankie 您给的连接只有协议文档,没有demo
                  另外,官方还能提供UDS上位机烧录软件么?

                  FrankieF 1 条回复 最后回复
                  0
                  • FrankieF 离线
                    FrankieF 离线
                    Frankie YunTu
                    在 回复了 yxydoctor 最后由 编辑
                    #12

                    yxydoctor 都有,联系一下代理商获取

                    yxydoctorY 2 条回复 最后回复
                    0
                    • yxydoctorY 离线
                      yxydoctorY 离线
                      yxydoctor
                      在 回复了 Frankie 最后由 编辑
                      #13

                      Frankie 好的好的

                      1 条回复 最后回复
                      0
                      • yxydoctorY 离线
                        yxydoctorY 离线
                        yxydoctor
                        在 回复了 Frankie 最后由 编辑
                        #14

                        Frankie 可否帮忙看看,链接文件这样理解对不对。这是YTC默认生成的MCAL链接文件。
                        假如就以默认链接做BOOT固件的化,用户APP有关链接文件的处理。

                        // 1-BVT: APP应该是不需要这段定义。
                        define exported symbol BVT_memory_start = 0x2000000;
                        define exported symbol BVT_memory_end = 33556479;
                        define region BVT = mem:[from BVT_memory_start to BVT_memory_end]; /*0x800*/
                        
                        // 2-IVT:需偏移如+0x4000
                        define exported symbol IVT_memory_start = 0x2000800;
                        define exported symbol IVT_memory_end = 33557503;
                        define region IVT = mem:[from IVT_memory_start to IVT_memory_end]; /*1024*/
                        
                        // 3-NC_TEXT:需偏移如+0x4000
                        define exported symbol NC_TEXT_memory_start = 0x2000c00;
                        define exported symbol NC_TEXT_memory_end = 33603583;
                        define region NC_TEXT = mem:[from NC_TEXT_memory_start to NC_TEXT_memory_end]; /*0xB400*/
                        
                        // 4-TEXT:需偏移如+0x4000
                        define exported symbol TEXT_memory_start = 0x200c000;
                        define exported symbol TEXT_memory_end = 35651583;
                        define region TEXT = mem:[from TEXT_memory_start to TEXT_memory_end]; /*0x1F4000*/
                        
                        // 5-dflash: 不需要偏移
                        define exported symbol FEE_memory_start = 0x6000000;
                        define exported symbol FEE_memory_end = 100925439;
                        define region FEE = mem:[from FEE_memory_start to FEE_memory_end]; /*0x40000*/
                        
                        // 6-IVT_RAM,默认占用ITCM的最后1K,不需要偏移
                        define exported symbol IVT_RAM_memory_start = 0x0;
                        define exported symbol IVT_RAM_memory_end = 1023;
                        define region IVT_RAM = mem:[from IVT_RAM_memory_start to IVT_RAM_memory_end]; /*0x400*/
                        
                        // 7-ITCM,不需要偏移
                        define exported symbol CODE_RAM_memory_start = 0x400;
                        define exported symbol CODE_RAM_memory_end = 32767;
                        define region CODE_RAM = mem:[from CODE_RAM_memory_start to CODE_RAM_memory_end]; /*0x7C00*/
                        
                        // 8-DTCM,不需要偏移
                        define exported symbol D_RAM_memory_start = 0x20000000;
                        define exported symbol D_RAM_memory_end = 536997887;
                        define region D_RAM = mem:[from D_RAM_memory_start to D_RAM_memory_end]; /*0x1F000*/
                        
                        // 7-STACK,默认占用DTCM的最后4K,不需要偏移
                        define exported symbol STACK_memory_start = 0x2001f000;
                        define exported symbol STACK_memory_end = 537001983;
                        define region STACK = mem:[from STACK_memory_start to STACK_memory_end]; /*4096*/
                        
                        // 8-NC区,默认占用OCRAML的最后64K(开的好大),不需要偏移
                        define exported symbol NC_RAM_memory_start = 0x20020000;
                        define exported symbol NC_RAM_memory_end = 537067519;
                        define region NC_RAM = mem:[from NC_RAM_memory_start to NC_RAM_memory_end]; /*0x10000*/
                        

                        因为这种方案是唯一选择,加密就在BOOT代码中做了。

                        1 条回复 最后回复
                        0

                      • 云途论坛规则/Yuntu Forum Rules

                        发帖前请查看

                      • YCT离线License申请流程

                        帮助没办法联网的电脑使用YCT

                      • YT CONFIG TOOL调查问卷

                        帮助改进和优化YT CONFIG TOOL,有机会抽取YTM32B1ME0 EVB哦...

                      • demo
                        12
                        can
                        9
                        lin stack
                        6
                        yt-link
                        5
                        vscode
                        3
                        adc模块
                        2
                        i2c
                        2
                        uuid
                        2
                        Online Users
                        fzh0907F
                        fzh0907
                        文锐文
                        文锐
                        qq970555603Q
                        qq970555603
                        Peihua_HanP
                        Peihua_Han
                        WKYW
                        WKY
                        LCZOUYIWENL
                        LCZOUYIWEN
                        monM
                        mon
                        yt0069Y
                        yt0069
                        runR
                        run
                        • 登录

                        • 登录或注册以进行搜索。
                        • 第一个帖子
                          最后一个帖子
                        0
                        • 版块
                        • 最新
                        • 标签
                        • 热门