摘要
创建受限状态 VMO 并将其绑定到当前线程。
声明
#include <zircon/syscalls-next.h>
zx_status_t zx_restricted_bind_state(uint32_t options, zx_handle_t* out_vmo);
说明
创建一个 VMO 来存储 zx_restricted_state_t
。将 VMO 绑定到当前的
以便后续对 zx_restricted_enter()
的调用使用它
在进入/退出受限模式时恢复/保存受限模式状态。
虽然返回的 VMO out_vmo
与 zx_vmo_create()
创建的 VMO 类似,但某些操作不受支持,并且可能会因出错而失败。例如,不支持调整大小和创建子 VMO。地图绘制
取消映射,以及通过 zx_vmo_read()
/zx_vmo_write()
执行读取/写入操作
支持。
一个线程一次只能绑定一个受限状态 VMO。尝试绑定其他 VMO 会替换已绑定的 VMO。
只有在关闭最后一个用户句柄、 移除上一位用户映射,并发生以下情况之一:
而是通过
zx_restricted_bind_state()
替换的。系统会通过
zx_restricted_unbind_state()
明确将其移除。线程被销毁。
与任何其他 VMO 一样,VMO 映射后,系统会保留其映射,以便调用方可以关闭句柄并通过映射直接访问内存。
在 VMO 的偏移量 0 处进入受限模式 zx_restricted_state_t
后
系统将加载 ,执行将相应地继续。退出受限模式后,线程的受限状态将保存在 VMO 的偏移量 0 处。
options 必须为零。
权限
调用方的作业政策必须允许 ZX_POL_NEW_VMO
。
错误
ZX_ERR_INVALID_ARGS
out_vmo 是无效的指针、NULL 或 options
是 0 以外的任何值。
ZX_ERR_NO_MEMORY
因内存不足而失败。用户空间没有好办法处理这种(不太可能)错误。
在未来的 build 中,此错误将不再出现。