2.执行adb shell "echo 3> /sys/module/mali/parameters/mali_debug_level"
3.执行adb shell cat /proc/kmsg
观察输出的log,确认有mali GP:xxxx job 或者 mali pp:xxx job 出现,表示gpu在处理任务。
黑屏期间观察有无上述log出现,如果没有再尝试操作触摸屏,看看有无上述log出现。如果一直没有,则说明surfaceflinger没有工作
SurfaceFlinger和powermanagerservice的屏幕状态不一样,
SurfaceFlinger通过/sys/power/wait_for_fb_sleep和/sys/power/wait_for_fb_wake来判断
powermanagerservice通过按键来判断
SurfaceFlinger先调用了turnElectronBeamOn,powermanagerservice后调用了 turnElectronBeamOff 导致修改见红色部分
status_t SurfaceFlinger::turnElectronBeamOnImplLocked(int32_t mode)
{
DisplayHardware& hw(graphicPlane(0).editDisplayHardware());
/*
if (hw.canDraw()) {
// we're already on
return NO_ERROR;
}
*/
status_t SurfaceFlinger::turnElectronBeamOffImplLocked(int32_t mode)
{
DisplayHardware& hw(graphicPlane(0).editDisplayHardware());
if (!hw.canDraw()) {
// we're already off
return NO_ERROR;
}
if (mode & ISurfaceComposer::eElectronBeamAnimationOff) {
electronBeamOffAnimationImplLocked();
}
// always clear the whole screen at the end of the animation
glClearColor(0,0,0,1);
glDisable(GL_SCISSOR_TEST);
glClear(GL_COLOR_BUFFER_BIT);
glEnable(GL_SCISSOR_TEST);
hw.flip( Region(hw.bounds()) );
// hw.setCanDraw(false);//
return NO_ERROR;
}