基于i.mx6ull实现linux快速启动(1秒内)

6 篇文章 0 订阅

在某些特殊场景下,需要快速启动linux,减少外围数据丢失。并可以快速响业务需求。

本文介绍如何在imx6ull+qspi nor flash的前提下,实现1秒启动应用。

 

整个实现过程参考了网上的一篇文章,好像是在ATMEL的Cortex-A9上实现的,我找到后贴出来。

我的硬件环境:16MB QSPI Nor Flash,128MB DDR3 DRAM,imx6ull主处理器。

我的实现步骤是这样的。

修改rcw,默认从QSPI Flash启动,配置速率为99Mbps,4线SPI模式读取。

使用lzo压缩内核,文件系统使用initramfs,并与内核绑在一起。bootargs也放在内核中。

去掉uboot,通过imx6ull的freertos/裸机例程,实现一个bootloader。

这个bootloader中有几个关键功能

(1)初始化DDR参数,这个是通过工具调出来的,是PCB相关的。

(2)QSPI Flash读取,通过4线模式读取。

(3)拷贝内核镜像到DDR中,实现bootm函数跳到内核自解压。

 

裁剪内核,将大部分驱动程序做成系统启动后动态加载的,尤其是耗时时间长的外设(可以通过启动log,有重点的关闭驱动)。

 

未完待续。。。

  • 6
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
i.MX6ULL是NXP半导体推出的一款低功耗、高集成度的应用处理器,适用于嵌入式系统和物联网设备。在使用i.MX6ULL处理器运行Linux操作系统时,安全性是一个重要的考虑因素。 i.MX6ULL Linux系统的安全性可以从多个方面来考虑。首先,Linux操作系统本身具有良好的安全性,具备权限管理、访问控制、安全隔离等功能。通过合理的配置和管理,可以保护系统免受外部攻击。 其次,i.MX6ULL芯片本身也提供了一些安全特性,如硬件加密引擎和安全启动功能。硬件加密引擎可以加密数据传输,确保数据的机密性;安全启动功能则提供了验证和保护引导加载程序的机制,防止恶意软件的篡改。 此外,i.MX6ULL还支持TrustZone技术,通过硬件隔离将系统分成安全世界和非安全世界。在安全世界中,可以运行关键的安全任务,而非安全世界则可以运行一般的应用程序。这种硬件隔离可以提供额外的保护,防止恶意程序对关键数据和系统功能的攻击。 最后,开发者在使用i.MX6ULL时还可以采取一些安全措施,如定期更新操作系统和软件包、使用强密码、限制外部设备的访问等。同时,定期进行安全漏洞扫描和风险评估,及时修复发现的漏洞和弱点,也是提高系统安全性的重要手段。 综上所述,i.MX6ULL在运行Linux操作系统时可以通过合理配置、硬件特性和开发者的安全措施来提高系统的安全性,保障系统和数据的保密性、完整性和可用性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值