内核IO复用与epoll
在前面的文章中,详细介绍了如何在内核驱动程序中实现poll、select和用户空间应用程序使用poll、select。本文将详细介绍如何在内核驱动中实现epoll和用户程序如何使用epoll。
1、epoll介绍
epoll 是一种事件轮询,是轮询的一种变体。 它可以用作 Edge 或 Level Triggered 接口,并且可以很好地扩展到大量监视的文件描述符。
- Edge triggered:只有当一个新事件被 epoll 排队时,对 epoll_wait 的调用才返回。
- Level triggered:只要条件成立,对 epoll_wait 的调用就会返回。
下面通过一个例子来更好地理解 Level 和 Edge 触发。
假设已经用 epoll 注册了一个管道用于读取。 该应用程序一次只能读取 1Kb 数据。 如果你想读取 5Kb,你必须读取 5 次。
假设有人向管道写入了 5Kb 的数据并且可以读取。 当应用程序调用 epoll_wait 时,它会在数据可用时立即返回。 因此,应用程序读取 1Kb 数据并再次调用 epoll_wait。 如果您将 epoll 配置为边缘触发,那么 epoll 将不会返回,直到有人再次将(新事件)写入管道,即使还有 4