黑屏 判断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;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值