有关mtkfb中screen_update队列的分析

本文详细分析了MTKFB中screen_update_task任务的创建、调度以及screen_update_wq等待队列的工作流程。screen_update_task通过wait_event_interruptible进入休眠,由mtkfb_lcd_complete_interrupt中断回调唤醒,中断处理函数_LCD_InterruptHandler触发中断,调用mtkfb_lcd_complete_interrupt检查has_pending_update并唤醒等待队列。整个过程涉及中断处理、线程调度和屏幕更新。
摘要由CSDN通过智能技术生成

首先定义了一个task

static struct task_struct *screen_update_task = NULL;

在probe中进行了初始化:

    init_waitqueue_head(&screen_update_wq);
    screen_update_task = kthread_create( screen_update_kthread, NULL, "screen_update_kthread");

    if (IS_ERR(screen_update_task)) {
        return PTR_ERR(screen_update_task);
    }
    wake_up_process(screen_update_task);

上面的代码已经完成这个task的创建,并通过wake_up_process将该kthread给运行起来了,在adb shell 下 ps也是可以看到一个screen_update_kthread的进程的。

线程中的函数

static int screen_update_kthread(void *data)
{
struct sched_param param = { .sched_priority = RTPM_PRIO_SCRN_UPDATE };
sched_setscheduler(current, SCHED_RR, &param);   
    for( ;; ) {
        wait_event_interruptible(screen_update_wq, atomic_read(&has_pending_update));
        mtkfb_update_screen_impl();
atomic_set(&has_pending_update,0);
        if (kthread_should_stop())
            break;
    }
    return 0;
}

这个函数开始就通过sched_setschedulers来设置进行的调度,修改优先级,SCHED_RR表示居于时间片的调度,当时间片用完,会将该进程放到就绪队列中等待cpu的调度。

for循环中通过wait_event_interruptible函数设置screen_update_wq进入可中断的休眠。

加入kthread_should_stop()函数的原因是要在开启线程的函数中加入该函数,否则kthread_stop是不会起作用的。

mtkfb_update_screen_impl()函数会调用DISP_CHECK_RET(DISP_UpdateScreen(0, 0, fb_xres_update, fb_yres_update));来更新屏幕。


之后需要分析的是screen_update_wq这个wait_queue_head_t.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值