From: Sabre Shao Date: Thu, 9 Jul 2015 05:53:24 +0000 (+0800) Subject: amdgpu: add va range query interface X-Git-Tag: libdrm-2.4.63~35 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=12802da74f0e480bbde5a11df689329910893e87;p=platform%2Fupstream%2Flibdrm.git amdgpu: add va range query interface amdgpu_va_range_query interface is added so that client can query va range supported by specific device. Signed-off-by: Sabre Shao Reviewed-by: Jammy Zhou --- diff --git a/amdgpu/amdgpu.h b/amdgpu/amdgpu.h index fcd12b3..a38e488 100644 --- a/amdgpu/amdgpu.h +++ b/amdgpu/amdgpu.h @@ -1155,4 +1155,25 @@ int amdgpu_va_range_alloc(amdgpu_device_handle dev, */ int amdgpu_va_range_free(amdgpu_va_handle va_range_handle); +/** +* Query virtual address range +* +* UMD can query GPU VM range supported by each device +* to initialize its own VAM accordingly. +* +* \param dev - [in] Device handle. See #amdgpu_device_initialize() +* \param type - \c [in] Type of virtual address range +* \param offset - \c [out] Start offset of virtual address range +* \param size - \c [out] Size of virtual address range +* +* \return 0 on success\n +* <0 - Negative POSIX Error code +* +*/ + +int amdgpu_va_range_query(amdgpu_device_handle dev, + enum amdgpu_gpu_va_range type, + uint64_t *start, + uint64_t *end); + #endif /* #ifdef _AMDGPU_H_ */ diff --git a/amdgpu/amdgpu_vamgr.c b/amdgpu/amdgpu_vamgr.c index faffba2..d6ec9b4 100644 --- a/amdgpu/amdgpu_vamgr.c +++ b/amdgpu/amdgpu_vamgr.c @@ -31,6 +31,17 @@ static struct amdgpu_bo_va_mgr vamgr = {{0}}; +int amdgpu_va_range_query(amdgpu_device_handle dev, + enum amdgpu_gpu_va_range type, uint64_t *start, uint64_t *end) +{ + if (type == amdgpu_gpu_va_range_general) { + *start = dev->dev_info.virtual_address_offset; + *end = dev->dev_info.virtual_address_max; + return 0; + } + return -EINVAL; +} + static void amdgpu_vamgr_init(struct amdgpu_bo_va_mgr *mgr, struct amdgpu_device *dev) { mgr->va_offset = dev->dev_info.virtual_address_offset;