最近在基于Linux kernel 3.14的版本移植Android4.4系统,移植过程中遇到了很多问题,现在记录一下做个备忘:
1. init.rc无法解析
由于Android4.4系统加强了文件安全的管理,对于启动配置文件增加写保护机制,将所有的rc文件和prop文件的权
限设为644就没这个问题了。
2. 控制台无法获取root权限
由于系统启动时,console的属主为shell,因此串口终端或者adb shell进去后没有root权限,将user shell改为user
root就解决了。
3. 进入控制台后,有些目录无法执行ls等操作
由于Android4.4已经引入了selinux机制,有些目录被保护起来了。解决此问题需要关闭selinux,并且将init.rc里面
的所有restorecon操作都屏蔽掉。
4. zygote初始化时dalvik虚拟机起不来
如果在烧录固件的时候,没有区分根文件系统和system分区(即根文件系统和system分区合并在一起),则会出
现此问题。原因在于zygote初始化时会检查/system分区是否挂载OK,如果遍历所有已挂载分区没有找到system
(ANDROID_ROOT),则认为系统启动出现问题,然后抛出异常。解决此问题,需要增加system分区,或者将检查
ANDROID_ROOT的这段代码注释掉。
5. surfaceflinger启动时提示EGL相关的库找不到
由于原生的安卓系统没有提供EGL和HwComper相关的硬件图形库,只能使用软件图形库libGLES_android,然而
该库默认只给模拟器用,真机启动时会忽略该库。因此SurfaceFlinger在初始化EGL时找不到正确的库,然后就异常
退出了。解决此问题,需要硬件平台厂商提供相关的硬件图形库,或者修改代码,强制使用libGLES_android。
6. zygote和各基础服务起来后进入不了桌面
由于进入桌面前会启动systemui service和launcher,这两个都会调用图像功能,会去初始化EGL,然后根据EGL
参数创建EGLSrfrace。因为强制使用软件渲染导致EGL的默认参数和系统不匹配,因此EGL初始化会失败,无法创建
EGLSurface。解决此问题,需要修改代码,关闭硬件渲染功能,强制使用软件渲染。
7. 系统启动后无法联网,iptable一直报异常
由于Android4.4增加了对ipv6的支持,需要kernel增加ipv6相关的配置,如果使用的是以太网,还需要在framework
层需要添加以太网的策略配置。