在写硬件访问服务程序时,修改了framework层相关模块,重新编译make snod,模拟器启动异常,停留在"android“界面。输出消息部分如下:
通过打印消息可以看出应该是模块依赖的问题。
上网查询,截取部分解决方法。
查看build/core/main.mk,发现里面有个droidcore命令,
尝试使用make droidcore编译后,模拟器成功运行,并打印出修改的log,后来仔细分析droidcore:
发现一开始是执行systemimage,于是我又尝试用make systemimage来编译:
修改framework中源码,在framework/base 中mm,退至源码根目录,make systemimage后,启动模拟器,修改效果成功显示。
Ps:
1.貌似执行make snod(systemimage no dependence)不行,看来要编上dependence才行。
2.在make systemimage 之后一定要关闭模拟器重开才行,执行adb shell stop,adb shell start也不行。
就是时间比较长,编一下要10分钟左右。
摘自网友文章:http://blog.youkuaiyun.com/zhanglongit/article/details/26220061
-------------------------------------------------------------------------------------------------------------------------
全编andorid后,单独修改编译一个framwork模块,make snod会有如下告警信息:
Warning: with dexpreopt enabled, you may need a full rebuild
使用这样make snod 出来的镜像,内核不能启动,模拟器一直停留在“android”标志状态。
查看log发现有如下错误打印:
DexOpt: mismatch dep signature for '/system/framework/framework.odex
查看makefile有这样的语句
# Enable dex-preoptimization to speed up the first boot sequence
# of an SDK AVD. Note that this operation only works on Linux for now
# 看起来这是一项为了加快第一次启动速度的特性
ifeq (true,$(WITH_DEXPREOPT))
$(warning Warning: with dexpreopt enabled, you may need a full rebuild.)
endif
修改方法1:
build/target/board/generic/BoardConfig.mk
ifeq ($(HOST_OS),linux)
ifeq ($(WITH_DEXPREOPT),)
WITH_DEXPREOPT := true #把这个改为false
endif
endif
修改方法2:
全编译的时候加载参数
make showcommands WITH_DEXPREOPT=false
这样编译出来的结果,如果以后单独修改打包运行,就不会有上述问题了。
摘自网友文章:http://blog.youkuaiyun.com/lqxandroid2012/article/details/49509499
在修改Android framework模块并编译后,遇到模拟器启动异常,停留在'android'界面。问题根源可能涉及模块依赖。通过执行`make droidcore`或`make systemimage`可以解决,同时揭示了dexpreopt可能导致的问题。解决方案包括在`BoardConfig.mk`中调整WITH_DEXPREOPT或在全编译时添加WITH_DEXPREOPT=false参数。
6826

被折叠的 条评论
为什么被折叠?



