Intel® QAT加速卡之同步异步模式

QAT 的两种操作模式

Intel® QAT API同时支持同步和异步两种操作模式。 为了获得最佳性能,该应用程序应能够向加速引擎提交多个未完成的请求。 提交多个未完成的请求可最大程度地减少加速引擎上的处理延迟。 这可以在应用程序中通过异步提交请求或使用多线程以同步模式提交请求来完成。开发人员可以选择最适合其应用程序和系统架构的操作模式。

下面对Intel® QAT的两种操作模式进行简单说明。

1. 异步操作

如果使用QAT的异步处理功能,用户需要通过API接口注册一个回调函数,如图3所示。一旦请求被发送到硬件加速器,操作的结果会以控制消息的形式返回给调用者,并且在加速引擎完成指定操作后,会执行用户注册的回调函数。 触发执行回调函数的机制是具体实现而定。 对于某些实现,回调函数将作为中断处理程序下半部中被调用。 还有一部分实现,回调函数将在轮询线程的上下文中被调用。 在这种情况下,用户应用程序负责创建和调度此轮询线程。
在这里插入图片描述

2. 同步操作

通过在Perform API的回调参数中提供NULL函数指针来指定同步操作,如下图所示。在这种情况下,该函数直到操作完成才返回。 在将请求发送到执行引擎之后,调用线程会阻塞到信号量或者其他同步机制上,但加速引擎处理完成后,SAL再将 处理结果返回到调用者线程。

操作完成后,用于同步机制的操作将解除阻塞,用户的操作将继续执行。 同步模式不能再有睡眠的上下文中调用执行。
在这里插入图片描述

posted @ 2020-08-13 08:32  叨陪鲤  阅读(95)  评论(0编辑  收藏  举报