【dsPIC33E】Bootloader(三)Bootloader下位机

2024-05-24 06:18
文章标签 bootloader 下位 dspic33e

本文主要是介绍【dsPIC33E】Bootloader(三)Bootloader下位机,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前面2节讲述了dsPIC33E的Flash存储结构以及Hex格式,接下来开始讲述如何编写Bootloader下位机和上位机。

本节讲述下位机的设计,考虑到执行效率和烧录时间,我们将主要解析工作放到上位机中,因为PC的执行速度远高于MCU。在上位机中,我们将Hex文件解析成一组一组的地址和数据组合,然后将一个地址和数据打包发送到Bootloader,Bootloader将其写入对应地址内。

我们先将地址空间分割成三段区域:

0x000000-0x0007FF: 第一段为起始跳转、复位和中断向量表

0x000800-0x0071FF: 第二段为Bootloader,此处预留0x6400长度,为了以后扩充,多预留了一点,后面再空一点点。

0x008000-0x02A800: 第三段为User App,注意最后一页(包含配置字)不要使用,擦除时会导致代码保护清零。

分别在Bootloader和AfterBootloader(即User App)项目中添加gld文件(从xc16安装文件夹下复制到项目目录下),修改对应的程序地址(修改program (xr)的起始地址和长度),这样编译时,会限制程序起始和结束地址。

以下我们将使用具体项目来说明,使用的芯片为dsPIC33EP256GP506

示例项目下载:https://download.csdn.net/download/u010875635/10819819

Bootloader中,最重要的就是2个功能,一是通信,二是Flash读写。由于不能使用中断,防止中断向量表与User App的冲突,通信都采用查询模式。开发板正好有现成的串口,本例采用串口通信,考虑到后面可能会使用CAN,因此核心数据长度为8bytes,串口本身校验功能差,我们再在前后分别增加2个字节,总计12个字节。

此例总共设有5中命令,兼容Bootloader和User App,分别为:EntryBootloader(User App中可用)、Reset、Data、DataEnd、CheckBootloader、Erase。

EntryBootloaderBootloader不适用,User App中可用,由上过机发送过来的命令,用于在User App中复位到Bootloader,以便于进行代码烧写工作;Bootloader启动时会向上位机发送EntryBootloader回馈,表示进入Bootloader。

ResetBootloader中可用,上位机发送过来的命令,用于烧写完毕后,重启系统,User App启动时会向上位机发送Reset回馈表示已经于User App。

Data接收到的为数据,由上位机发送过来,Bootloader将其写入flash。

这篇关于【dsPIC33E】Bootloader(三)Bootloader下位机的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/997605

相关文章

Bootloader -- U-Boot 介绍

Bootloader -- U-Boot 介绍 1 介绍1.1 概述1.2 知名 BootloaderLILO (Linux Loader)GRUB (GNU GRand Unified Bootloader)LoadlinROLO (Rockbox Loader)EtherbootLinuxBIOS (现在叫 coreboot)BLOBU-BootRedBoot 1.3 BootLoade

iOS BootLoader详解

目录 Pre-Introduction – EFIPre-Introduction – NVRAMPre-Introduction – Ramdisk and APFS FileSystemBootLoader IntroductionBootLoader Process 正文 1. Pre-Introduction – EFI EFI(Extensible Firmware Interf

【嵌入式】一种优雅的 bootloader 跳转APP 的方式

【嵌入式】一种优雅的 bootloader 跳转APP 的方式 0. 个人简介 && 授权须知1. 前言2. 干净的跳转3.程序的 noinit 段4. 利用noinit段实现优雅的跳转4.1 检查栈顶地址是否合法4.2 栈顶地址 +44.3 __set_MSP 5.OTA 过后的运行逻辑 0. 个人简介 && 授权须知 📋 个人简介 💖 作者简介:大家好,我是喜欢记录

ARM单片机使用CAN总线部署BootLoader

1.引言 1.1.单片机开发BootLoader意义 单片机开发BootLoader的原因主要与其在嵌入式系统中的关键作用有关。BootLoader是硬件启动的引导程序,它在操作系统内核或用户应用程序运行之前执行。以下是单片机开发BootLoader的主要原因: 初始化硬件设备:当单片机上电或重启时,BootLoader会首先负责初始化计算机硬件设备,如处理器、内存、外设等。这些初始化操作确

初识BootLoader(二)

BootLoader的功能 BootLoader,通常是驻留在ECU非易失性存储器(NVM,None Valitale Momory)中的一段程序加载代码,每次ECU复位后,都会运行bootloader。它会检查是否有来自通信总线的远程程序加载请求,如果有,则进入bootloader模式,建立与程序下载端(通常为PC上位机)的总线通信并接收通信总线下载的应用程序、解析其地址和数据代码,运行N

zynq-7015启动分析及裸机BootLoader编写(未完待续)

使用lwip-tcp远程对QSPI进行更新、QSPI FLASH启动 W25Q128资料: W25Q128JV datasheet(1/78 Pages) WINBOND | 3V 128M-bit serial flash memory with dual/quad spi (alldatasheet.com) UG585资料: Zynq 7000 SoC Technical Referenc

android的recovery,fastboot和bootloader

虽然最近,我主领的android项目重构工作,正在有条不 紊的开展当中,但是因为项目一直迭代,技术开发不能影响业务的展开。而公司的人都是干缝缝补补的活的,所以,把这个工作时间可能会拉的比较长。大概估计的是半年完成,实际肯定会少于半年。总比之前画半年的鸡蛋,好的多。         哪怕现在公司别人由于业务少,技术就不动我,我是受不了安逸舒适的。除了思考项目的事情。。最近一段时间,

初识BootLoader

一、 BootLoader的概念 引导加载程序是系统加电后运行的第一段软件代码。回忆一下PC的体系结构我们可以知道,PC机中的引导加载程序由BIOS(本质是一段固件程序)和位于硬盘MBR中的BootLoader(如LILO、GRUB等)组成。BIOS在完成硬件检测和资源分配后,将硬盘MBR中的BootLoader读到系统的RAM中,然后将控制权交给BootLoader。BootLoader的主要

bootloader启动引导

一、Bootloader概述 简而化之的说,在嵌入式系统中Bootloader就是在系统CPU开启或计算机复位的时候运行的程序。这段程序可以初始化硬件设备、建立内存空间映射图,将系统的软硬件环境带到一个合适状态,为最终调用操作系统内核准备好正确的环境。在嵌入式系统中,通常并没有像BIOS那样的固件程序(有的嵌入式CPU也会内嵌一段短小的启动程序),因此整个系统的加载启动任务就完全由Bootloa

高通平台bootloader显示logo图片的过程

platform:  mtk8937 以下为开机后调用关系: 根据不同的平台,这个函数所在的文件不同; 我们项目属于msm8952系列; void target_display_init(const char *panel_name){struct oem_panel_data oem;int32_t ret = 0;uint32_t panel_loop = 0;set_panel_