摘要
创建资源对象。
声明
#include <zircon/syscalls.h>
zx_status_t zx_resource_create(zx_handle_t parent_rsrc,
uint32_t options,
uint64_t base,
size_t size,
const char* name,
size_t name_size,
zx_handle_t* resource_out);
说明
zx_resource_create()
会创建一个资源对象,以便与其他 DDK 系统调用搭配使用。资源通常会分发给总线驱动程序,很少需要驱动程序使用驱动程序协议直接与其交互。资源对象可授予对从 base 开始且不超过 base + size 的地址空间范围的访问权限。kind 有两个特殊值:ZX_RSRC_KIND_ROOT
和 ZX_RSRC_KIND_SYSTEM
。根资源没有关联的范围。系统资源是一种范围资源,是多个资源的父级,所有这些资源的大小均为 1,用于对系统调用进行特权检查。
parent_rsrc 必须是类型为 ZX_RSRC_KIND_ROOT
的资源的句柄,或者与请求的类型匹配且范围包含 [base, base+size] 的资源。
options 必须指定要创建的资源类型,并且可以包含可选标志。有效的资源类型包括 ZX_RSRC_KIND_MMIO
、ZX_RSRC_KIND_IRQ
、ZX_RSRC_KIND_IOPORT
(仅限 x86)、ZX_RSRC_KIND_ROOT
、ZX_RSRC_KIND_SMC
(仅限 ARM)和 ZX_RSRC_KIND_SYSTEM
。ZX_RSRC_KIND_SYSTEM
的有效基数包括 ZX_RSRC_SYSTEM_HYPERVISOR_BASE
、ZX_RSRC_SYSTEM_VMEX_BASE
、ZX_RSRC_SYSTEM_DEBUG_BASE
、ZX_RSRC_SYSTEM_INFO_BASE
、ZX_RSRC_SYSTEM_CPU_BASE
、ZX_RSRC_SYSTEM_POWER_BASE
、ZX_RSRC_SYSTEM_MEXEC_BASE
、ZX_RSRC_SYSTEM_ENERGY_INFO_BASE
、ZX_RSRC_SYSTEM_IOMMU_BASE
、ZX_RSRC_SYSTEM_PROFILE_BASE
、/ ZX_RSRC_SYSTEM_MSI_BASE
、ZX_RSRC_SYSTEM_DEBUGLOG_BASE
和 ZX_RSRC_SYSTEM_STALL_BASE
。这些都具有 size 1。ZX_RSRC_KIND_ROOT
必须与 base 和 size 的零值搭配使用,因为它不使用地址空间范围。
ZX_RSRC_FLAG_EXCLUSIVE
是可选标志。如果提供了 ZX_RSRC_FLAG_EXCLUSIVE
,则系统调用将尝试独占预留请求的地址空间区域,以防止在该区域存在期间其他资源创建与其重叠。
name 和 name_size 是可选的,并会截断为 ZX_MAX_NAME_LENGTH
- 1。此名称仅供调试 / 工具使用,不会被内核使用。
成功时,resource_out 中会返回有效的资源句柄。
返回值
zx_resource_create()
会在成功时返回 ZX_OK
。如果失败,则返回负错误值。
返回的句柄将具有 ZX_RIGHT_TRANSFER
(允许通过 zx_channel_write()
将其发送到另一个进程)、ZX_RIGHT_DUPLICATE
(允许复制句柄)、ZX_RIGHT_INSPECT
(允许使用 zx_object_get_info()
和 ZX_RIGHT_WRITE
检查对象,该标志由 zx_resource_create()
本身进行检查。
权限
parent_rsrc 必须为 ZX_OBJ_TYPE_RESOURCE
类型且具有 ZX_RIGHT_WRITE
。
错误
ZX_ERR_BAD_HANDLE
parent_rsrc 句柄无效。
ZX_ERR_WRONG_TYPE
parent_rsrc 句柄不是资源句柄。
ZX_ERR_ACCESS_DENIED
parent_rsrc 句柄不是 kind 或 ZX_RSRC_KIND_ROOT
资源。
ZX_ERR_INVALID_ARGS
options 包含无效的类型或标志组合、name 是无效的指针,或者指定的kind 为 ZX_RSRC_KIND_ROOT
,但 base 和 size 不为 0。
ZX_ERR_NOT_FOUND
未找到合适的资源分配。如果地址范围无效、范围已归独占资源所有,或者存在常规资源且调用方尝试在同一范围内创建独占资源,就会发生这种情况。
ZX_ERR_NO_MEMORY
因内存不足而失败。用户空间没有很好的方法来处理这种(不太可能发生的)错误。在未来的 build 中,此错误将不再出现。