自己用C语言写RH850 F1KM serial bootloader

   了解更多关于bootloader 的C语言实现,请加我Q扣: 1273623966 (验证信息请填 bootloader),欢迎咨询或定制bootloader(在线升级程序)。

  手上有块Renesas RH850 F1KM的板子,几个月前有些空,准备给它写个串口bootloader。 写完后发现在debug模式下,bootloader工作很正常,能够正常烧写应用程序。但是在release模式下一直有R_FCL_ERR_PARAMETER错误,一直解决不了。后来非常忙,就没再去倒弄它了。昨天有点空,就仔细地查看了下。发现在boot.asm中有以下定义。

;-----------------------------------------------------------------------------
; hdwinit
; Specify RAM addresses suitable to your system if needed.
;-----------------------------------------------------------------------------
GLOBAL_RAM_ADDR .set 0

GLOBAL_RAM_END .set 0

LOCAL_RAM_ADDR .set 0

LOCAL_RAM_END .set 0

查看datasheet, 修改成实际值后, 就运行正常了。很有意思。

;-----------------------------------------------------------------------------
; hdwinit
; Specify RAM addresses suitable to your system if needed.
;-----------------------------------------------------------------------------
GLOBAL_RAM_ADDR .set 0xFEDD8000
GLOBAL_RAM_END .set 0xFEDE0000
LOCAL_RAM_ADDR .set 0xFEDE0000
LOCAL_RAM_END .set 0xFEE00000

接下来介绍下RH850 F1KM 串口 bootloader 如何实现。

       首先介绍实现环境,IDE是CS+, C编译器是CC-RH, 硬件板是我的学习板,  详细如下:

IDE :        CS+  for CC V7.00.00 [13 Jun 2018]

Compiler:    CC-RH V2.00.00

MCU:          RH850 F1KM R7F701684

FCL:   RENESAS_FCL_RH850_T01_V2.12

      我的bootloader和application的memory map设计如下:

bootloader code range: 0x0000~0x17FFF

application code range: 0x18000~0x1FFFFF (offset 0x18000)

bootloader code range设置,需要通过修改CS+ bootloader工程的Linker Option来实现。

application code range设置,  也需要修改CS+ application工程的Linker Option来实现。具体可以查阅CS+的帮助。

另外,application 的interrupt 入口需要在CS+ application工程中的boot.asm中添加。

      bootloader 的上位机是串口终端hyperterm(超级终端)。 hyperterm的配置(串口配置)如下:

baud rate:   19200

data bytes:   8

parity:           none

stop bits:       1

flow control : none

line delay:     150ms

     上电后, bootloader 初始化uart (baudrate-data bytes-parity-stop bits-flow control 要和hyperterm的配置一致,19200-8-none-1-none, 否则通信不了)。bootloader 然后每隔1S左右打印一个 '.' , 打印完6个'.' (6S)就跳转到application. 如果要更新程序,就在6S内在hyperterm 窗口中敲一回车。bootloader 收到回车(代表握手成功)就开始擦除application code range. 打印 “Erasing *********"  每擦除一个block (1024 bytes) 就增加打印一个 ”*“直到所有application blocks都擦除完毕,并打印”Done“(代表擦除成功)。

      hyperterm 窗口显示了bootloader 完成Erase后打印的”Done“,就操作hyperterm采用发送文本的方式发送application 的hex文件,一行接一行的发送,每发送一行就暂停240ms (配置hyperterm参数line delay = 240ms).

      bootloader 每接收一行,原样打印,并解读里面的数据类型,地址,长度,数据,和Checksum, 如果数据类型为S1或S2,就将接收到的数据烧写到对应的地址。直到最后一行也处理完毕。整个烧写过程都没问题就打印”Program Rewritten Complete“ “(代表更新成功)。并跳转到application。 如果烧写过程有问题就打印”Program Rewritten Complete with Error“。

      以上就是bootloader的更新程序的整个逻辑。代码框架如下:

 

void M_Bootloader_MainFunc(void)
{
     switch (bootState)
    {
        case BOOT_HANDSHAKE:
            M_Bootloader_Handshake();
            break;
        case BOOT_ERASE:
            M_Bootloader_Erase();
            break;
        case BOOT_RECEIVE:
            M_Bootloader_Receive();
            break;
        case BOOT_PROGRAM:
            M_Bootloader_Write();
            break;
        case BOOT_VERIFY:
            M_Bootloader_IVerify();
            break;
        case BOOT_PREJUMP:
            Prejump_To_Application();
            break;
        case BOOT_JUMPTO_APP:
            Jump_To_Application();
            break;
        default:
            break;
    }
}

整个过程, hyperterm中打印出来的内容就是更新流程log. 下面是一个完整的更新流程的部分log.

....BOOT Mode             
Erasing*****************************Done                                        
S0E0000726838353046314B6D6F7468                               
S090000E0020080010093                     
S214018000E0022480000000000000000000000000E4                                            
S2140180101F00E0020E800000000000000000000CB                                           
S214018020E0020080000000000000000000000000E8                                            
S214018030E002F07F000000000000000000000000E9                                            
S214018040E002E27F000000000000000000000000E7                                            
S214018050E002D27F00000000000000000000000E7                                           
S214018060E002C07F000000000000000000000000E9                                            
S2140180701F00E002B07F00000000000000000000CA                                            
S214018080E002A07F00000000000000000000000E9                                          
S214018090E002907F000000000000000000000000E9                                            
S2140180A0E002807F000000000000000000000000E9
posted @ 2019-05-26 19:58  GeekyGeek  阅读(1692)  评论(0编辑  收藏  举报