android系统重新刷ROM简记(一)

本文深入探讨了Android系统中的关键文件组成及其作用,并详细解释了如何进行大范围的系统改造。通过理解烧写过程中的uboot.bin、boot.img、system.img等文件的作用,以及数据文件夹下的各种组件,读者可以更好地掌握Android系统定制化的方法。同时,文章还提供了具体的刷机文件结构解析和文件操作步骤,帮助开发者实现对系统的大规模优化。

      当需要对android系统进行大刀阔斧的改造的时候,应该清晰的了解android各个image的组成才能做到庖丁解牛。

      首先在android烧写过程中需要烧写的文件主要包括uboot.bin\boot.img\system.img\userdata.img\recovery.img等文件。

    小米的刷机文件主要包括data\META-INF\recovery\system\blob\boot.img\file_contexts文件。

Data文件夹下只有一个文件夹miui从名字可以知道里面存放的文件主要是小米的用户界面文件。

system/app  这个里面主要存放的是常规下载的应用程序,可以看到都是以APK格式结尾的文件。在这个文件夹下的程序为系统默认的组件,自己安装的软件将不会出现在这里,而是\data\文件夹中

system/bin  这个目录下的文件都是系统的本地程序,从bin文件夹名称可以看出是binary二进制的程序,里面主要是Linux系统自带的组件(命令)

system/etc  从文件夹名称来看保存的都是系统的配置文件,比如APN接入点设置等核心配置。

system/fonts  字体文件夹,除了标准字体和粗体、斜体外可以看到文件体积最大的可能是中文字库,或一些unicode字库其中DroidSansFallback.ttf文件大小

system/framework  framework主要是一些核心的文件,从后缀名为jar可以看出是是系统平台框架。

system/lib  lib目录中存放的主要是系统底层库,一些so文件,如平台运行时库
system/media/audio  铃声音乐文件夹,除了常规的铃声外还有一些系统提示事件音。
system/usr  用户文件夹,包含共享、键盘布局、时间区域文件等

system/priv-app 可以存放自己编写的一些app文件

system/vendor 存放产品相关文件

bootimg文件是由Image和ramdisk.img文件生成。在/build/core/Makefile文件中有相关的描述。# the boot image, which is a collection of other images.

INTERNAL_BOOTIMAGE_ARGS := \

        $(addprefix --second ,$(INSTALLED_2NDBOOTLOADER_TARGET)) \

        --kernel $(INSTALLED_KERNEL_TARGET) \

        --ramdisk $(INSTALLED_RAMDISK_TARGET)

在system/core/mkbootimg/bootimg.h中有具体打包的描述。

** +-----------------+

** | boot header     | 1 page

** +-----------------+

** | kernel          | n pages

** +-----------------+

** | ramdisk         | m pages

** +-----------------+

** | second stage    | o pages

** +-----------------+

从上面能够清晰的看出boot.img文件的构成主要是将kernel以及ramdisk.img文件打包并且添加文件头完成。

如果需要修改小米官方给出的文件的情况下,可以使用

#./split_bootimg.pl boot.img

Page size: 2048 (0x00000800)

Kernel size: 6695672 (0x00662af8)

Ramdisk size: 1276106 (0x001378ca)

Second size: 0 (0x00000000)

Board name:

Command line:

Writing boot.img-kernel ... complete.

Writing boot.img-ramdisk.gz ... Complete.

解包ramdisk文件,首先要创建一个文件夹用于存放解压后的文件,进入文件夹之后,执行下面命令:

#gzip -dc ../boot.img-ramdisk.gz | cpio -i

对文件作出修改之后,需要重新做成boot.img文件。

使用mkbootfs工具(mkbootfs工具是编译完毕Android源代码以后,就会在~/android-src/out/host/linux-x86/bin自动生成)来重新创建ramdisk,可以使用如下命令来操作:

#mkbootfs ./ramdisk | gzip > ramdisk-new.gz

 使用mkbootimg来重新创建boot.img,mkbootimg也可以在~/android-src/out/host/linux-x86/bin目录中可以找到:

#mkbootimg --cmdline 'no_console_suspend=1 console=null' --kernel boot.img-kernel --ramdisk ramdisk-new.gz -o boot-new.img

 

 

 android系统重新刷ROM简记(二)

 

 

 

课程简述  Android是目前最为流行的移动操作系统,它的开发涉及到多个知识领域。本课程将深入介绍Android系统启动过程中的重要组成部分——init进程,并探讨与之相关的多项关键技术。我们还将提供实际的开发案例,以RK3399开发板为例,通过演示Android产品配置、init启动流程、selinux权限管理、init.rc启动脚本定制等实际案例,让学员深入理解这些技术在实际产品开发中的应用场景和实现方法,提高学员的实际开发能力和经验,从而更好地应对实际产品开发中遇到的问题和挑战。知识运用方向学习Android启动方面的知识,可以参与如下实际开发工作项:启动流程定制: 根据产品需求调整Android启动流程,包括修改init.rc脚本、修改启动顺序和等待时间、加入自定义服务等。属性系统定制: 通过Android属性系统定制化启动流程,例如增加产品版本信息、定制开机音量等。日志系统分析: 掌握日志的捕捉、分析和排错技术,在启动过程中,需要加入调试信息来方便开发人员进行调试,同时需要进行日志的优化,避免日志输出过多占用过多的系统资源。selinux安全策略定制:在Android系统中,selinux是种安全机制,用于保护系统的敏感资源和数据。在实际开发中,可能需要对selinux策略进行定制,以确保系统的安全性和稳定性。课程内容主要内容简述1, RK3399 开发板操作这部分内容重点介绍如何在FIreFly开发板上将Android 10系统运行起来, 包含编译FireFly的Android源码下载和编译, 镜像烧录运行,内核和模块编译,以及RK3399内核启动init进程的过程。2, 产品定制这部分讲解获取到方案商或者原厂提供的源码后, 如何定制个新的产品,产品配置文件和模型, 原始代码中的配置文件和定制化东西3, Android日志代码编写之前讲过Android的日志系统, 并没涉及到代码编写, 这个部分重点讲解C/C++, java代码编写日志的API和代码4, 属性系统Android中,属性使用的非常频繁的,可以用来作为进程间通信,也可以用于些行为控制, 这个部分会重点介绍属性系统框架, API接口, 属性文件等知识点5,selinux进程对文件进行访问时,Android 4.3就开始集成了selinux权限管控, 如果需要启动某个脚本或者服务, selinux的配置就避免不了,并且Android8之后, Android系统对进程访问的权限管控的非常严格。6, init.rc脚本Android定义的种脚本, 改脚本是有init进程启动, 是非常重要的个脚本, 会包含系统中的其他很多脚本, 在我们系统开发时, 我们经常通过这个脚本进行些定制化动作。7, init进程代码分析想要了解系统,就必须对源码进行分析和理解, 这个章节,带大家去跟读init进程代码, 这样,换了另外Android版本,完全就可以去读代码, 知道有什么变化。 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值