OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 600|回复: 3

从网络烧录rootfs黑屏、无反应

[复制链接]

2

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
70
金钱
70
注册时间
2021-3-16
在线时间
9 小时
发表于 2024-4-16 23:07:11 | 显示全部楼层 |阅读模式
20金钱
我不想使用 MGFTools 烧录,这个工具用在开发环境有点太麻烦了,想直接从 uboot 烧录 rootfs 到 emmc,于是我在 ubuntu 制作了一个rootfs的虚拟文件系统镜像,在 ubuntu 挂载后复制了所有 rootfs 的文件到这个虚拟文件系统镜像。


制作过程如下:


dd if=/dev/zero of=imx6ull_rootfs.img ds=1M count=1024
sudo mkfs.ext4 -F -L linuxroot imx6ull_rootfs.img
sudo mount imx6ull_rootfs.img /tmp_rootfs
sudo cp -rfp nfs/rootfs/* ./tmp_rootfs
sudo umount tmp_rootfs
sudo e2fsck -p -f imx6ull_rootfs.img
sudo resize2fs -M imx6ull_rootfs.img

至此虚拟文件系统制作完成,下面只需要把它烧录到 emmc 即可,但是在烧录的过程中出现问题。

制作完毕后在 imx6ull 的开发版上,通过 uboot 烧录进 emmc 的第二个分区:

tftp 80800000 imx6ull_rootfs.img
mmc write 80800000 A280 ee66000

我通过网络启动内核镜像后,在 linux 使用 fdisk 把 emmc 格式化成两个分区,前一个分区 20 M,用于存放内核镜像、设备树和 uboot 镜像,第二个分区暂时全部用于根文件系统,未格式化,第二个分区的起始块就是 A280,根文件系统大小是 ee66000。
在烧录的过程中,tftp 下载可以成功,但是 mmc write 到 emmc 的第二个分区的过程中,没有执行完成,uboot 就黑屏了,log 也一直卡在 :

MMC write: dev # 1, block # 41600, count 249978880 ...

我等了大概十多分钟仍然没有变化,应该是 uboot 卡死了,但是不知道卡在哪里?是否全部写成功?以及为什么卡住?可能需要加些 log 确认。

后来我断电 reset,再从网络进入linux,手动 mount 第二个分区可以成功,文件夹看起来和我做的根文件系统镜像完全相同,文件系统格式是 ext4,但是不确定文件有无损坏和缺少,毕竟没有看到mmc write成功。

有没有类似经验的兄弟给我解答以下,或者提供一下分析方向,谢谢!







最佳答案

查看完整内容[请看2#楼]

算了,我暂时没有找到解决办法,看起来要么是 uboot 有 bug,要么是有我没有注意到的 emmc 和 DRAM 的特性。 暂时不去管了,我现在只想把我开发的东西移到 emmc 进行脱机验证,不从 uboot 更新的话直接从 linux 用 dd 指令覆盖文件系统也可以。 目前我暂时的解决方案是把存储镜像的分区从 20 M 扩大到 500 M,然后从 nfs 网络映射的根文件系统拷贝 imx6ull_rootfs.xml 到这个分区,再从 linux 使用 dd 指令覆盖根文件系统的 ...
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

2

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
70
金钱
70
注册时间
2021-3-16
在线时间
9 小时
 楼主| 发表于 2024-4-16 23:07:12 | 显示全部楼层
算了,我暂时没有找到解决办法,看起来要么是 uboot 有 bug,要么是有我没有注意到的 emmc 和 DRAM 的特性。

暂时不去管了,我现在只想把我开发的东西移到 emmc 进行脱机验证,不从 uboot 更新的话直接从 linux 用 dd 指令覆盖文件系统也可以。

目前我暂时的解决方案是把存储镜像的分区从 20 M 扩大到 500 M,然后从 nfs 网络映射的根文件系统拷贝 imx6ull_rootfs.xml 到这个分区,再从 linux 使用 dd 指令覆盖根文件系统的分区,实现开发板 emmc 内的根文件系统的升级。

这样做的好处是可以直接从网络升级,就是略显麻烦,而且暂时不能自动完成整个过程,必须要在 linux 手动覆盖根文件系统,不过目前至少可以正常从 emmc 进入根文件系统了。

回复

使用道具 举报

2

主题

446

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4133
金钱
4133
注册时间
2018-5-14
在线时间
902 小时
发表于 2024-4-17 10:31:07 | 显示全部楼层
内存多大?内存256M的话,tftp一个超过256M的文件系统就会溢出内存,基本都是分包接收和写入的。mfgtool里使用的pipe传输文件系统所以不存在这个问题。
回复

使用道具 举报

2

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
70
金钱
70
注册时间
2021-3-16
在线时间
9 小时
 楼主| 发表于 2024-4-17 15:51:37 | 显示全部楼层
姚先起 发表于 2024-4-17 10:31
内存多大?内存256M的话,tftp一个超过256M的文件系统就会溢出内存,基本都是分包接收和写入的。mfgtool里 ...

从资料看的话,我这块核心板使用的是512MB的核心板,根文件系统两百兆左右,容量应该是够的。如果容量不够,tftp下载的时候应该也会把uboot覆盖掉,直接在tftp下载的时候就会出问题。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-24 15:40

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表