黑屏 判断SF是否正常工作debug 方法


1.连上adb

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;
}



你可能感兴趣的:(黑屏 判断SF是否正常工作debug 方法)