我修改了framework里的Activity.java,在他的onCreate()方法中加了一行log,这样其它activity调用的时候就会触发这行log。然后编译framework,会生成framework.jar,然后push framework.jar到机器验证。
1、Activity.java的onCreate方法中添加log
shell
frameworks/base⟫ find -name Activity.java
./core/java/android/app/Activity.java
frameworks/base⟫ grep -nr "cmy" ./core/java/android/app/Activity.java
1818: android.util.Log.d("cmy-test1", "Activity is onCreate");
2、单编framework
在在初始化完环境后,执行以下命令,这里我用的是make framework-minus-apex:
bash
# 进入工程根目录
make framework-minus-apex
# 或者
make framework
framework-minus-apex: 它编译 framework 的核心库,速度比全量编译快得多。- 结果文件 : 编译完成后,我这里生成的framework.jar路径为
out\target\product\qssi\system\framework\framework.jar。
3、adb push
正常情况下,你adb root,然后remount,再然后push到设备后,然后重启,framework.jar的修改就生效了。 但是我这里remount失败了,下面记录我恢复remount的过程:
bash
C:\Users\cmy>adb push Z:\workspace\A8003B-NEW\LA.QSSI.15.0\LINUX\android\out\target\product\qssi\system\framework\framework.jar /system/framework
adb: error: failed to copy 'Z:\workspace\A8003B-NEW\LA.QSSI.15.0\LINUX\android\out\target\product\qssi\system\framework\framework.jar' to '/system/framework/framework.jar': remote couldn't create file: Read-only file system
Z:\workspace\A8003B-NEW\LA.QSSI.15.0\LINUX\android\out\target\product\qssi\system\framework\framework.jar: 1 file pushed, 0 skipped. 44.5 MB/s (43486481 bytes in 0.933s)
我这台设备是debug版本,可以root,但是remount就报错,说解锁bootloader:
bash
C:\Users\cmy>adb remount
Device must be bootloader unlocked
首先打开 开发者模式中的OED解锁,这里OED解锁只是允许你去解锁,和真正执行解锁的操作两者不是一回事。
一、确认当前 Bootloader 状态
先执行:
adb reboot bootloader
进入 fastboot 后:
fastboot flashing get_unlock_ability
如果返回:
makefile
get_unlock_ability: 1
说明 允许解锁。
再执行:
fastboot getvar unlocked
如果返回:
yaml
unlocked: no
说明 Bootloader 仍然锁着。
二、真正解锁 Bootloader
在 fastboot 模式执行:
fastboot flashing unlock
设备屏幕会出现确认界面,用 音量键选择 Unlock,电源键确认。
等到设备启动后,就可以正常adb remount了。