mkyaffs2image后usr不见了

elesun8 2015-01-08 01:26:00
mkyaffs2image后usr不见了

PC_虚拟机_Linux_redhat:
#makeyaffs2image rootf_qtopia_qt4 rootfs.img
rootf_qtopia_qt4 有177MB大小,而rootfs.img只有17MB大小
这正不正常???

我把rootfs.img通过supervivi USB下载到mini2440 NandFlash,系统能够启动,但是根目录下usr目录不见了,又多了一个lost+found目录。

这又是怎么回事啊???

多谢高手指点
...全文
465 16 打赏 收藏 转发到动态 举报
写回复
用AI写文章
16 条回复
切换为时间正序
请发表友善的回复…
发表回复
elesun8 2015-02-01
  • 打赏
  • 举报
回复
还是没有解决,恳请高手指点。多谢了
zhxianbin 2015-01-25
  • 打赏
  • 举报
回复
mini2440 的资料网上多的是,Google了, mkyaffs2img 工具编译 u-boot 就会生成
elesun8 2015-01-24
  • 打赏
  • 举报
回复
如何解决啊,恳请指教
elesun8 2015-01-23
  • 打赏
  • 举报
回复
mkfs.jffs2工具制作jffs2文件系统
hnhujun518 2015-01-23
  • 打赏
  • 举报
回复
ECC校验不过导致的。yaffs用到了额外的oob数据。
Creator_莫言 2015-01-22
  • 打赏
  • 举报
回复
换个jffs2的制作工具试试?
elesun8 2015-01-22
  • 打赏
  • 举报
回复
lost+found是yaffs自己弄出来的,里头主要放一些已经损坏的文件。 yaffs没有压缩功能???
elesun8 2015-01-22
  • 打赏
  • 举报
回复
有人可以提供一个好用的img工具吗?用于制作yaffs文件系统镜像
zhxianbin 2015-01-11
  • 打赏
  • 举报
回复
redhat9 好像还是 2.4 的内核,和这个问题有没有关系不知道
帅得不敢出门 2015-01-10
  • 打赏
  • 举报
回复
怀疑是你的制作工作版本过低有bug.
elesun8 2015-01-10
  • 打赏
  • 举报
回复
是不是因为我操作系统的问题,我用的PC 虚拟机 redhat9 Linux
elesun8 2015-01-10
  • 打赏
  • 举报
回复
mkyaffs2image-128 还是不行 我实验室不能上网啊,只能晚上回去上网
zhxianbin 2015-01-09
  • 打赏
  • 举报
回复
引用 2 楼 elesun8 的回复:
177MB mkyaffs2img 就变成 17MB了,这不正常吧 难道是要用mkyaffs2image-128M这个工具才可以?
有时间在这问,你试一下不就知道了吗
elesun8 2015-01-09
  • 打赏
  • 举报
回复
恳请指点啊,,,,,,
elesun8 2015-01-08
  • 打赏
  • 举报
回复
177MB mkyaffs2img 就变成 17MB了,这不正常吧 难道是要用mkyaffs2image-128M这个工具才可以?
zhxianbin 2015-01-08
  • 打赏
  • 举报
回复
应该是不正常的 lost+found是正常的
使用方法:http://blog.csdn.net/asmcvc/article/details/11770851 工具: unyaffs,mkyaffs2image 其中unyaffs有windows版本和linux版本,mkyaffs2image只有linux版本。 windows版本的unyaffs用法: 把system.img复制到unyaffs的相同目录下,cmd命令下cd到unyaffs的目录下,然后执行命令:unyaffs system.img unyaffs会把system.img解压到其目录下。 linux版本的unyaffs用法: 把unyaffs复制到/usr/bin目录下,并修改权限为可执行。 然后cd到system.img目录下(假定目录为system目录),执行命令:unyaffs system.img 然后对system目录下的文件进行修改。 注意:修改完后的文件要修改一下权限,尽量和其他文件的权限保持一致。例如:chmod 644 framework-res.apk mkyaffs2image用法: 复制到/usr/bin目录下,并修改权限为可执行。 这里以打包system目录为system.img为例,执行命令: mkyaffs2image system system.img 然后把新生成的system.img复制替换掉原:adt-bundle-windows-x86\sdk\system-images\android-17\armeabi-v7a\system.img 执行bat批处理命令启动模拟器: D:\adt-bundle-windows-x86\sdk\tools\emulator-arm.exe -avd AndroidVM -partition-size 128 这里以修改android系统启动画面为例: 打开解包目录下的\framework\framework-res.apk 替换图片:framework-res.apk\assets\images\android-logo-mask.png为下图: 然后对\framework\framework-res.apk文件重新签名,复制到linux下后修改文件权限和原来一致。 然后mkyaffs2image system system.img打包生成新的system.img,替换原来的system.img,并启动模拟器,效果图如下: 修改代码: 工具:odextools(参考:《一键odex批量合并工具odextools的重新整理与使用》)、dexopt-wrapper 其中odextools.bat的代码: 批处理有一处bug:每打包一次会把odex文件删除掉,导致在后面的打包过程中会出现找不到:system/framework/core.odex类似的错误,因此只需要在打包完后不删除odex文件即可,找到del /f !apkx!.odex 1>nul 2>nul改为:::del /f !apkx!.odex 1>nul 2>nul,也就是注释掉这一行代码。 具体使用方法(操作在windows下): 在odextools\romdir目录下创建文件夹:system 利用unyaffs解包system.img后,把所有文件复制到system目录下。 然后运行odextools.bat,如图: 选择一个需要整合odex的目录选项即可。odextools.bat会自动设置环境变量,使用baksmali.jar来反编译odex为smali,然后再调用smali.jar打包为classes.dex, 然后再打包到相应的apk包(framework目录下对应的是jar后缀的,实际上也是个apk包),最后再重新签名。 如果要修改代码,则需要把上面重新打包生成的apk文件,利用常规方法反编译后修改smali代码,例如插桩输入log信息。然后再回编译并重新签名。 最后一步:因为system.img中的apk是优化过的,apk主目录下是没有classes.dex文件的,而是一个被优化过的odex文件,用于优化启动速度。 因此需要将修改后的apk包再用dexopt-wrapper优化apk包后生成出odex文件,然后删除apk包里的classes.dex,并在相同目录下放置与apk包同名的odex文件。 按照原system目录的文件结构组织好后,目录复制到linux环境下使用mkyaffs2image重新打包成system.img。

4,436

社区成员

发帖
与我相关
我的任务
社区描述
Linux/Unix社区 内核源代码研究区
社区管理员
  • 内核源代码研究区社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧