中断发生率上限

摘要

将中断对象绑定到端口。

声明

#include <zircon/syscalls.h>

zx_status_t zx_interrupt_bind(zx_handle_t handle,
                              zx_handle_t port_handle,
                              uint64_t key,
                              uint32_t options);

说明

zx_interrupt_bind() 用于将中断对象绑定或取消绑定到端口。

中断对象只能绑定到单个端口,并且只能绑定一次。中断只能绑定到使用 ZX_PORT_BIND_TO_INTERRUPT 选项创建的端口。

当绑定的中断对象被触发时,系统会将 ZX_PKT_TYPE_INTERRUPT 数据包传送到其绑定的端口,并附带 zx_packet_interrupt_t 中触发中断的时间戳(相对于 ZX_CLOCK_BOOT)。绑定中断时使用的将显示在 zx_port_packet_tkey 字段中。

如果要绑定的中断处于触发状态,系统会向中断绑定的端口发送 ZX_PKT_TYPE_INTERRUPT 数据包,其中包含中断触发的时间戳。此数据包需要正常处理。

如需绑定到端口,请在 options 中传递 ZX_INTERRUPT_BIND

如需解除之前绑定的端口,请在 options 中传递 ZX_INTERRUPT_UNBIND。要解除绑定,需要 port_handle,但忽略 key。解除绑定端口会移除之前排入该端口的数据包。

在传送另一个数据包之前,必须使用 zx_interrupt_ack() 系统调用重新启用绑定中断。(几乎在所有情况下)最好在完全处理中断包后再执行此操作。尤其是在多个线程从端口读取数据包的情况下,如果处理线程重新启用中断并已触发,则数据包将立即传送到等待线程。

中断数据包通过端口上的专用队列传送,优先级高于非中断数据包。

权限

handle 必须为 ZX_OBJ_TYPE_INTERRUPT 类型且具有 ZX_RIGHT_READ

port_handle 必须为 ZX_OBJ_TYPE_PORT 类型且具有 ZX_RIGHT_WRITE

返回值

zx_interrupt_bind() 会在成功时返回 ZX_OK。如果失败,则返回负错误值。

错误

ZX_ERR_BAD_HANDLE handleport_handle 不是有效的句柄。

ZX_ERR_WRONG_TYPE handle 不是中断对象,或者 port_handle 不是端口对象。

ZX_ERR_CANCELEDhandle 调用了 zx_interrupt_destroy()

ZX_ERR_BAD_STATE 线程正在使用 zx_interrupt_wait() 等待中断

ZX_ERR_ACCESS_DENIED handle 句柄缺少 ZX_RIGHT_READ,或者 port_handle 句柄缺少 ZX_RIGHT_WRITE

ZX_ERR_ALREADY_BOUND此中断对象已绑定。

ZX_ERR_INVALID_ARGS 选项不是 ZX_INTERRUPT_BINDZX_INTERRUPT_UNBIND

ZX_ERR_NOT_FOUND 端口与绑定的端口不匹配。

另请参阅