s3c6410 RomCode文档读后总结

发布时间:2024-09-13  

最近无意中看到一篇关于s3c6410 RomCode的介绍,结合自己的经验,做个总结。

首先贴张图,具体描述下该芯片的启动方式及具体流程。

因为s3c6410的板子多数是从SD或者Nand方式启动,重点就先放在Nand启动上。

启动基本流程:

  • 上图中的IROM为芯片固化程序,被称为BL0,开机后最先运行,它会去做一些硬件初始化动作,代码里通过检测GPN[15:13]管脚状态从相应设备指定区域BL1中拷贝4KB执行代码到Stepping stone中运行;

  1. Disable the Watch-Dog Timer

  2. Initialize the TCM.

  3. Initialize the Block Device Copy Function.

  4. Initialize the stack region.

  5. Initialize the PLL.

  6. Initialize the instruction cache.

  7. Initialize the heap region.

  8. Copy the BL1 to the stepping stone region.

  9. Verify the integrity of BL1.

  10. Jump to the stepping stone.

  • BL1中主要完成外部sdram和uart的初始化,并拷贝BL2至sdram中;

  • 跳转到sdram中的对应地址执行剩下的bootloader,完成加载运行kernel和user image的功能。

    代码流程图如下:

  • 个人总结:

    1. 以目前市场上手机平台为例,基本都在RomCode中添加了uart和usb下载功能,搭配PC端工具直接完成对flash的烧写,使整个流程更符合开发需求。

    2. 在文中结尾有关于Error Handling的介绍

    • 如果出现nand ecc failure,软件会配置GPN15管脚产生以下波形;

    • 当使能Secure Boot功能,出现校验BL1完整性失败时,GPN15产生以下波形;

    考虑到越来越多的安全需求,芯片的Secure Boot功能不可或缺,但是在功能调试中却难以分析,通过这种方式便可以快速定位问题原因,后续考虑在方案中添加异常波形设置。

    笔者在开发手机Secure Boot方案时,功能调试过程中刷死了很多机器,但是却无法快速定位,基本每次都要接上Trace32进行调试,如果添加GPIO状态可以快速甄别,协助定位问题。


    文章来源于:电子工程世界    原文链接
    本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。

    我们与500+贴片厂合作,完美满足客户的定制需求。为品牌提供定制化的推广方案、专属产品特色页,多渠道推广,SEM/SEO精准营销以及与公众号的联合推广...详细>>

    利用葫芦芯平台的卓越技术服务和新产品推广能力,原厂代理能轻松打入消费物联网(IOT)、信息与通信(ICT)、汽车及新能源汽车、工业自动化及工业物联网、装备及功率电子...详细>>

    充分利用其强大的电子元器件采购流量,创新性地为这些物料提供了一个全新的窗口。我们的高效数字营销技术,不仅可以助你轻松识别与连接到需求方,更能够极大地提高“闲置物料”的处理能力,通过葫芦芯平台...详细>>

    我们的目标很明确:构建一个全方位的半导体产业生态系统。成为一家全球领先的半导体互联网生态公司。目前,我们已成功打造了智能汽车、智能家居、大健康医疗、机器人和材料等五大生态领域。更为重要的是...详细>>

    我们深知加工与定制类服务商的价值和重要性,因此,我们倾力为您提供最顶尖的营销资源。在我们的平台上,您可以直接接触到100万的研发工程师和采购工程师,以及10万的活跃客户群体...详细>>

    凭借我们强大的专业流量和尖端的互联网数字营销技术,我们承诺为原厂提供免费的产品资料推广服务。无论是最新的资讯、技术动态还是创新产品,都可以通过我们的平台迅速传达给目标客户...详细>>

    我们不止于将线索转化为潜在客户。葫芦芯平台致力于形成业务闭环,从引流、宣传到最终销售,全程跟进,确保每一个potential lead都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>