Why do we need to call poll_wait in poll?

前端 未结 3 574
野趣味
野趣味 2021-01-11 15:05

In LDD3, i saw such codes

static unsigned int scull_p_poll(struct file *filp, poll_table *wait)
{
    struct scull_pipe *dev = filp->private_data;
    uns         


        
相关标签:
3条回答
  • 2021-01-11 15:45

    The poll file_operation sleeps if you return 0

    This is what was confusing me.

    When you return non-zero, it means that some event was fired, and it wakes up.

    Once you see this, it is clear that something must be tying the process to the wait queue, and that thing is poll_wait.

    Also remember that struct file represents "a connection between a process and an open file", not just a filesystem file, and as such it contains the pid, which is used to identify the process.

    Playing with a minimal runnable example might also help clear things up: https://stackoverflow.com/a/44645336/895245

    0 讨论(0)
  • 2021-01-11 15:47

    poll_wait adds your device (represented by the "struct file") to the list of those that can wake the process up.

    The idea is that the process can use poll (or select or epoll etc) to add a bunch of file descriptors to the list on which it wishes to wait. The poll entry for each driver gets called. Each one adds itself (via poll_wait) to the waiter list.

    Then the core kernel blocks the process in one place. That way, any one of the devices can wake up the process. If you return non-zero mask bits, that means those "ready" attributes (readable/writable/etc) apply now.

    So, in pseudo-code, it's roughly like this:

    foreach fd:
        find device corresponding to fd
        call device poll function to setup wait queues (with poll_wait) and to collect its "ready-now" mask
    
    while time remaining in timeout and no devices are ready:
        sleep
    
    return from system call (either due to timeout or to ready devices)
    
    0 讨论(0)
  • 2021-01-11 15:55

    poll_wait triggers when there is an expected event occurred on any of the fd's it is waiting on OR it hits timeout.

    Check the mask to know which event triggered poll_wait. If you don't want poll_wait to trigger on such event, you can configure it while registering file descriptor to poll fd.

    0 讨论(0)
提交回复
热议问题