【DM365启动机制与Boot】深入解析

DM365是一款由德州仪器(TI)推出的DaVinci系列数字媒体处理器,广泛应用于多媒体设备、视频处理和图像处理等领域。
其启动过程涉及到复杂的硬件初始化和软件加载流程,理解这一过程对于开发和调试基于DM365的系统至关重要。


DM36X的启动机制遵循一个标准的流程,当系统加电或复位后,CPU会从预先设定的地址读取第一条指令。
DM36X提供了多种启动方式,主要分为两种:通过外部存储器接口AEMIF(NOR Flash/OneNand)引导启动和通过ARM内部ROM(AIROM)引导启动。
启动模式的选择由BTSEL[2:0]引脚的状态决定。


例如,当BTSEL[2:0]设置为001时,系统将从AEMIF执行引导启动代码,即从外部的OneNand或Nor Flash启动。
而AIROM则支持多种启动模式,包括BTSEL[2:0]=000的NAND Boot,BTSEL[2:0]=010的MMC/SD Boot,以及BTSEL[2:0]=101的SPI Boot等。


Nand Boot Mode是DM365的一种常见启动方式,但因为处理器的AIRAM空间有限且NAND Flash不支持XIP(执行-in-place)技术,因此需要经过三个阶段的代码来完成从NAND Flash引导启动操作系统。
这一流程包括了初始化硬件、加载用户引导加载器(UBoot)到内存以及执行UBoot。


User Bootloader是DM365启动过程中的关键部分,其源码主要位于PSP包的board_utilities/flash_utils目录下。
入门代码由汇编文件start.S开始,负责切换操作模式、建立堆栈,并跳转到main函数。
在main函数中,LOCAL_boot函数负责实际的引导功能,包括调用Device_init()和NANDBOOT_copy()。


Device_init()函数完成了平台的底层初始化,如电源域、时钟、DDR、EMIF、UART、I2C和TIMER等模块的设置。
它首先屏蔽和清除中断,然后通过调用DEVICE_PSCInit启用各模块的电源和时钟,接着配置PINMUX,设置PLL1,配置DDR控制器,EMIF模块,串口0,TIMER0和I2C控制器。


当检测到启动模式配置寄存器(BOOTCFG)的BTSEL[2:0]为000时,系统将调用NAND_init()初始化NAND Flash,并通过NANDBOOT_copy()将紧随其后的Bootloader代码复制到DDR2内存中,以便于后续的程序执行。


Bootloader是嵌入式系统的重要组成部分,它的主要任务是为操作系统提供加载环境。
Bootloader的特点包括:早期系统初始化、设备驱动加载、引导操作系统、支持交互式操作等。
根据工作模式,Bootloader可以分为固件阶段和加载阶段,前者主要负责硬件初始化,后者则负责加载操作系统映像。


DM365的启动过程涉及到硬件配置、软件加载和系统初始化等多个环节,对开发人员理解和优化系统性能具有深远的影响。
了解这些知识,可以帮助我们更好地理解和调试基于DM365的系统,提高其稳定性和效率。
2025/5/20 13:14:23 530KB
1
我的其他资源都是免费的,是对于c语言初学者的帮助比较大的,其中有单片机,ARM,数据结构,window编程,MFC编程,cocos2dx,unity3d自己编写的小游戏。
2025/5/7 12:02:02 1.6MB MFC
1
FS4412开发板配套交叉编译工具链32-bitLSBexecutable,ARM,version1(SYSV),forGNU/Linux2.6.38
2025/5/2 21:23:47 27.19MB 4412工具链
1
由于目前的嵌入式处理速度与PC相比还有一段差距,对于复杂的图像处理略显乏力,所以统筹两者优点,设计实现了一种高效的远程视频实时人脸识别系统。
设计采用嵌入式ARM作为开发平台,并接入摄像头和无线网卡来实现前端部分视频的采集和传输。
PC作为接收端,并配置开源的视觉处理工具OpenCV实现人脸识别和达到视频监控的目的。
通过两者的结合既利用嵌入式优势,也获得了PC的处理速度,而且由于网络化,所以对监控的环境,距离等可以随意的调整,对工业要求或特定场合有一定的借鉴作用。
2025/4/21 17:17:16 1.54MB 视频监控; 人脸识别; OpenCV; ARM
1
基于ARM的贪吃蛇游戏设计报告,详细描述了如何在ARM的硬件基础上设计一款贪吃蛇游戏,以实现随机果实,可控制方向,吃掉果实后蛇长度增长等功能
2025/4/19 22:45:38 1.27MB ARM 贪吃蛇
1
ffmpeg3.2版本,在Linux下交叉编译完成arm版本,亲测可用
2025/4/17 12:26:15 8.29MB ffmpeg arm 交叉编译
1
使用STM32F103C8T6和HMI通过MODBUS协议进行通讯,实现了线圈DI数据的上传HMI采用的是威纶通的TK6071iQ,附上ARM源程序和HMI组态程序
2025/4/16 21:57:23 1.33MB STM32 STM32F103C8T MODBUS HMI
1
教材地址:http://download.csdn.net/source/2799218http://download.csdn.net/source/2799234http://download.csdn.net/source/2799250相关资源:ppt课件:http://download.csdn.net/source/2418441源代码:http://download.csdn.net/source/2419140习题答案:http://download.csdn.net/source/2419155***************************************************************C语言经典之作,被誉为“近10年来最好的一部C语言著作”哈佛、麻省理工、斯坦福、加州伯克利分校、耶鲁等诸多名校计算机专业教材内容全面,覆盖C99标准,提供了对所有C99库函数的参考精心选择的近500道习题,贴近实践***************************************************************请注意:下载完,评论的同时,请点击评论框上方的五角星(共5个五角星),这样你的被扣的积分就可以返还了。
如果只评论,不点击小五角星,积分不会返还。
一定要先下载完,再评论。
如果先评论后下载,或者在下载的过程中评论,积分同样不会返还。
***************************************************************更多linux、ARM和C语言资源请参考:http://blog.csdn.net/arkofnoach/archive/2010/10/23/5960560.aspx
1
video&audiosource,veryeasytouse.精炼、高效、稳定的RTSP服务器组件,调用简单灵活,轻松嵌入部署到IPCamera(ARM型、Android型)中,也可用于PC桌面直播
2025/4/11 9:04:53 22.16MB RTSP
1
本设计能作为普通时钟用,而且能设置闹钟。
程序使用C语言进行编程,能动态显示当前时间,包括时、分、秒,并且用串口助手显示
2025/4/10 19:22:38 2.13MB ARM的时钟
1
共 490 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡