diff options
author | Marek Olšák <marek.olsak@amd.com> | 2020-06-09 03:19:04 -0400 |
---|---|---|
committer | Eric Engestrom <eric@engestrom.ch> | 2020-06-24 23:03:50 +0200 |
commit | be4a86c9efb088b95ee380006dd4c3aeb11e8ce4 (patch) | |
tree | ad5657e3734a28448890d0878b043021375a5e58 | |
parent | 7c1ddbc4478500e307bb083f5fa0afdb05ea12f1 (diff) |
ac/surface: add a wrapper structure to hold ADDR_HANDLE
and more things in the future.
Reviewed-by: Pierre-Eric Pelloux-Prayer <pierre-eric.pelloux-prayer@amd.com>
(cherry picked from commit 4cf674c8f730bfa7c8dfe8b4ebe86f1f4e5f1bb9)
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/5422>
-rw-r--r-- | .pick_status.json | 2 | ||||
-rw-r--r-- | src/amd/common/ac_surface.c | 64 | ||||
-rw-r--r-- | src/amd/common/ac_surface.h | 11 | ||||
-rw-r--r-- | src/amd/vulkan/winsys/amdgpu/radv_amdgpu_winsys.c | 4 | ||||
-rw-r--r-- | src/amd/vulkan/winsys/amdgpu/radv_amdgpu_winsys.h | 3 | ||||
-rw-r--r-- | src/amd/vulkan/winsys/null/radv_null_winsys.h | 1 | ||||
-rw-r--r-- | src/gallium/winsys/amdgpu/drm/amdgpu_winsys.c | 4 | ||||
-rw-r--r-- | src/gallium/winsys/amdgpu/drm/amdgpu_winsys.h | 3 |
8 files changed, 54 insertions, 38 deletions
diff --git a/.pick_status.json b/.pick_status.json index 557097b1717..fcc030ee734 100644 --- a/.pick_status.json +++ b/.pick_status.json @@ -5413,7 +5413,7 @@ "description": "ac/surface: add a wrapper structure to hold ADDR_HANDLE", "nominated": false, "nomination_type": null, - "resolution": 4, + "resolution": 1, "master_sha": null, "because_sha": null }, diff --git a/src/amd/common/ac_surface.c b/src/amd/common/ac_surface.c index 992444dd70d..3931a4a716b 100644 --- a/src/amd/common/ac_surface.c +++ b/src/amd/common/ac_surface.c @@ -50,6 +50,10 @@ #define CIASICIDGFXENGINE_ARCTICISLAND 0x0000000D #endif +struct ac_addrlib { + ADDR_HANDLE handle; +}; + static void *ADDR_API allocSysMem(const ADDR_ALLOCSYSMEM_INPUT * pInput) { return malloc(pInput->sizeInBytes); @@ -61,9 +65,9 @@ static ADDR_E_RETURNCODE ADDR_API freeSysMem(const ADDR_FREESYSMEM_INPUT * pInpu return ADDR_OK; } -ADDR_HANDLE amdgpu_addr_create(const struct radeon_info *info, - const struct amdgpu_gpu_info *amdinfo, - uint64_t *max_alignment) +struct ac_addrlib *ac_addrlib_create(const struct radeon_info *info, + const struct amdgpu_gpu_info *amdinfo, + uint64_t *max_alignment) { ADDR_CREATE_INPUT addrCreateInput = {0}; ADDR_CREATE_OUTPUT addrCreateOutput = {0}; @@ -123,7 +127,21 @@ ADDR_HANDLE amdgpu_addr_create(const struct radeon_info *info, *max_alignment = addrGetMaxAlignmentsOutput.baseAlign; } } - return addrCreateOutput.hLib; + + struct ac_addrlib *addrlib = calloc(1, sizeof(struct ac_addrlib)); + if (!addrlib) { + AddrDestroy(addrCreateOutput.hLib); + return NULL; + } + + addrlib->handle = addrCreateOutput.hLib; + return addrlib; +} + +void ac_addrlib_destroy(struct ac_addrlib *addrlib) +{ + AddrDestroy(addrlib->handle); + free(addrlib); } static int surf_config_sanity(const struct ac_surf_config *config, @@ -1107,7 +1125,7 @@ static bool is_dcc_supported_by_DCN(const struct radeon_info *info, } } -static int gfx9_compute_miptree(ADDR_HANDLE addrlib, +static int gfx9_compute_miptree(struct ac_addrlib *addrlib, const struct radeon_info *info, const struct ac_surf_config *config, struct radeon_surf *surf, bool compressed, @@ -1120,7 +1138,7 @@ static int gfx9_compute_miptree(ADDR_HANDLE addrlib, out.size = sizeof(ADDR2_COMPUTE_SURFACE_INFO_OUTPUT); out.pMipInfo = mip_info; - ret = Addr2ComputeSurfaceInfo(addrlib, in, &out); + ret = Addr2ComputeSurfaceInfo(addrlib->handle, in, &out); if (ret != ADDR_OK) return ret; @@ -1189,7 +1207,7 @@ static int gfx9_compute_miptree(ADDR_HANDLE addrlib, hin.numMipLevels = in->numMipLevels; hin.firstMipIdInTail = out.firstMipIdInTail; - ret = Addr2ComputeHtileInfo(addrlib, &hin, &hout); + ret = Addr2ComputeHtileInfo(addrlib->handle, &hin, &hout); if (ret != ADDR_OK) return ret; @@ -1224,7 +1242,7 @@ static int gfx9_compute_miptree(ADDR_HANDLE addrlib, xin.numSamples = in->numSamples; xin.numFrags = in->numFrags; - ret = Addr2ComputePipeBankXor(addrlib, &xin, &xout); + ret = Addr2ComputePipeBankXor(addrlib->handle, &xin, &xout); if (ret != ADDR_OK) return ret; @@ -1264,7 +1282,7 @@ static int gfx9_compute_miptree(ADDR_HANDLE addrlib, din.dataSurfaceSize = out.surfSize; din.firstMipIdInTail = out.firstMipIdInTail; - ret = Addr2ComputeDccInfo(addrlib, &din, &dout); + ret = Addr2ComputeDccInfo(addrlib->handle, &din, &dout); if (ret != ADDR_OK) return ret; @@ -1325,7 +1343,7 @@ static int gfx9_compute_miptree(ADDR_HANDLE addrlib, assert(surf->u.gfx9.dcc.pipe_aligned || surf->u.gfx9.dcc.rb_aligned); - ret = Addr2ComputeDccInfo(addrlib, &din, &dout); + ret = Addr2ComputeDccInfo(addrlib->handle, &din, &dout); if (ret != ADDR_OK) return ret; @@ -1385,7 +1403,7 @@ static int gfx9_compute_miptree(ADDR_HANDLE addrlib, addrin.dccKeyFlags.rbAligned = surf->u.gfx9.dcc.rb_aligned; addrout.addr = 0; - ret = Addr2ComputeDccAddrFromCoord(addrlib, &addrin, &addrout); + ret = Addr2ComputeDccAddrFromCoord(addrlib->handle, &addrin, &addrout); if (ret != ADDR_OK) return ret; @@ -1396,7 +1414,7 @@ static int gfx9_compute_miptree(ADDR_HANDLE addrlib, addrin.dccKeyFlags.rbAligned = 0; addrout.addr = 0; - ret = Addr2ComputeDccAddrFromCoord(addrlib, &addrin, &addrout); + ret = Addr2ComputeDccAddrFromCoord(addrlib->handle, &addrin, &addrout); if (ret != ADDR_OK) return ret; @@ -1422,7 +1440,7 @@ static int gfx9_compute_miptree(ADDR_HANDLE addrlib, fin.size = sizeof(ADDR2_COMPUTE_FMASK_INFO_INPUT); fout.size = sizeof(ADDR2_COMPUTE_FMASK_INFO_OUTPUT); - ret = gfx9_get_preferred_swizzle_mode(addrlib, surf, in, + ret = gfx9_get_preferred_swizzle_mode(addrlib->handle, surf, in, true, &fin.swizzleMode); if (ret != ADDR_OK) return ret; @@ -1433,7 +1451,7 @@ static int gfx9_compute_miptree(ADDR_HANDLE addrlib, fin.numSamples = in->numSamples; fin.numFrags = in->numFrags; - ret = Addr2ComputeFmaskInfo(addrlib, &fin, &fout); + ret = Addr2ComputeFmaskInfo(addrlib->handle, &fin, &fout); if (ret != ADDR_OK) return ret; @@ -1461,7 +1479,7 @@ static int gfx9_compute_miptree(ADDR_HANDLE addrlib, xin.numSamples = in->numSamples; xin.numFrags = in->numFrags; - ret = Addr2ComputePipeBankXor(addrlib, &xin, &xout); + ret = Addr2ComputePipeBankXor(addrlib->handle, &xin, &xout); if (ret != ADDR_OK) return ret; @@ -1501,7 +1519,7 @@ static int gfx9_compute_miptree(ADDR_HANDLE addrlib, else cin.swizzleMode = in->swizzleMode; - ret = Addr2ComputeCmaskInfo(addrlib, &cin, &cout); + ret = Addr2ComputeCmaskInfo(addrlib->handle, &cin, &cout); if (ret != ADDR_OK) return ret; @@ -1515,7 +1533,7 @@ static int gfx9_compute_miptree(ADDR_HANDLE addrlib, return 0; } -static int gfx9_compute_surface(ADDR_HANDLE addrlib, +static int gfx9_compute_surface(struct ac_addrlib *addrlib, const struct radeon_info *info, const struct ac_surf_config *config, enum radeon_surf_mode mode, @@ -1672,7 +1690,7 @@ static int gfx9_compute_surface(ADDR_HANDLE addrlib, break; } - r = gfx9_get_preferred_swizzle_mode(addrlib, surf, &AddrSurfInfoIn, + r = gfx9_get_preferred_swizzle_mode(addrlib->handle, surf, &AddrSurfInfoIn, false, &AddrSurfInfoIn.swizzleMode); if (r) return r; @@ -1711,7 +1729,7 @@ static int gfx9_compute_surface(ADDR_HANDLE addrlib, AddrSurfInfoIn.format = ADDR_FMT_8; if (!AddrSurfInfoIn.flags.depth) { - r = gfx9_get_preferred_swizzle_mode(addrlib, surf, &AddrSurfInfoIn, + r = gfx9_get_preferred_swizzle_mode(addrlib->handle, surf, &AddrSurfInfoIn, false, &AddrSurfInfoIn.swizzleMode); if (r) goto error; @@ -1730,8 +1748,8 @@ static int gfx9_compute_surface(ADDR_HANDLE addrlib, /* This is only useful for surfaces that are allocated without SCANOUT. */ bool displayable = false; if (!config->is_3d && !config->is_cube) { - r = Addr2IsValidDisplaySwizzleMode(addrlib, surf->u.gfx9.surf.swizzle_mode, - surf->bpe * 8, &displayable); + r = Addr2IsValidDisplaySwizzleMode(addrlib->handle, surf->u.gfx9.surf.swizzle_mode, + surf->bpe * 8, &displayable); if (r) goto error; @@ -1843,7 +1861,7 @@ error: return r; } -int ac_compute_surface(ADDR_HANDLE addrlib, const struct radeon_info *info, +int ac_compute_surface(struct ac_addrlib *addrlib, const struct radeon_info *info, const struct ac_surf_config *config, enum radeon_surf_mode mode, struct radeon_surf *surf) @@ -1857,7 +1875,7 @@ int ac_compute_surface(ADDR_HANDLE addrlib, const struct radeon_info *info, if (info->chip_class >= GFX9) r = gfx9_compute_surface(addrlib, info, config, mode, surf); else - r = gfx6_compute_surface(addrlib, info, config, mode, surf); + r = gfx6_compute_surface(addrlib->handle, info, config, mode, surf); if (r) return r; diff --git a/src/amd/common/ac_surface.h b/src/amd/common/ac_surface.h index 0dc43816593..ed3694ac63d 100644 --- a/src/amd/common/ac_surface.h +++ b/src/amd/common/ac_surface.h @@ -36,7 +36,7 @@ extern "C" { #endif /* Forward declarations. */ -typedef void* ADDR_HANDLE; +struct ac_addrlib; struct amdgpu_gpu_info; struct radeon_info; @@ -279,11 +279,12 @@ struct ac_surf_config { unsigned is_cube : 1; }; -ADDR_HANDLE amdgpu_addr_create(const struct radeon_info *info, - const struct amdgpu_gpu_info *amdinfo, - uint64_t *max_alignment); +struct ac_addrlib *ac_addrlib_create(const struct radeon_info *info, + const struct amdgpu_gpu_info *amdinfo, + uint64_t *max_alignment); +void ac_addrlib_destroy(struct ac_addrlib *addrlib); -int ac_compute_surface(ADDR_HANDLE addrlib, const struct radeon_info *info, +int ac_compute_surface(struct ac_addrlib *addrlib, const struct radeon_info *info, const struct ac_surf_config * config, enum radeon_surf_mode mode, struct radeon_surf *surf); diff --git a/src/amd/vulkan/winsys/amdgpu/radv_amdgpu_winsys.c b/src/amd/vulkan/winsys/amdgpu/radv_amdgpu_winsys.c index acb003e1533..0f7f5bcf3bf 100644 --- a/src/amd/vulkan/winsys/amdgpu/radv_amdgpu_winsys.c +++ b/src/amd/vulkan/winsys/amdgpu/radv_amdgpu_winsys.c @@ -55,7 +55,7 @@ do_winsys_init(struct radv_amdgpu_winsys *ws, int fd) ws->info.use_display_dcc_unaligned = false; ws->info.use_display_dcc_with_retile_blit = false; - ws->addrlib = amdgpu_addr_create(&ws->info, &ws->amdinfo, &ws->info.max_alignment); + ws->addrlib = ac_addrlib_create(&ws->info, &ws->amdinfo, &ws->info.max_alignment); if (!ws->addrlib) { fprintf(stderr, "amdgpu: Cannot create addrlib.\n"); return false; @@ -156,7 +156,7 @@ static void radv_amdgpu_winsys_destroy(struct radeon_winsys *rws) { struct radv_amdgpu_winsys *ws = (struct radv_amdgpu_winsys*)rws; - AddrDestroy(ws->addrlib); + ac_addrlib_destroy(ws->addrlib); amdgpu_device_deinitialize(ws->dev); FREE(rws); } diff --git a/src/amd/vulkan/winsys/amdgpu/radv_amdgpu_winsys.h b/src/amd/vulkan/winsys/amdgpu/radv_amdgpu_winsys.h index 8cbac290043..166b2dfe1ca 100644 --- a/src/amd/vulkan/winsys/amdgpu/radv_amdgpu_winsys.h +++ b/src/amd/vulkan/winsys/amdgpu/radv_amdgpu_winsys.h @@ -30,7 +30,6 @@ #include "radv_radeon_winsys.h" #include "ac_gpu_info.h" -#include "addrlib/inc/addrinterface.h" #include <amdgpu.h> #include "util/list.h" #include <pthread.h> @@ -41,7 +40,7 @@ struct radv_amdgpu_winsys { struct radeon_info info; struct amdgpu_gpu_info amdinfo; - ADDR_HANDLE addrlib; + struct ac_addrlib *addrlib; bool debug_all_bos; bool use_ib_bos; diff --git a/src/amd/vulkan/winsys/null/radv_null_winsys.h b/src/amd/vulkan/winsys/null/radv_null_winsys.h index 7953ab4792d..5bb31a7ffba 100644 --- a/src/amd/vulkan/winsys/null/radv_null_winsys.h +++ b/src/amd/vulkan/winsys/null/radv_null_winsys.h @@ -30,7 +30,6 @@ #include "radv_radeon_winsys.h" #include "ac_gpu_info.h" -#include "addrlib/inc/addrinterface.h" #include "util/list.h" #include <pthread.h> diff --git a/src/gallium/winsys/amdgpu/drm/amdgpu_winsys.c b/src/gallium/winsys/amdgpu/drm/amdgpu_winsys.c index a195dc8a136..7ac2a61bdfd 100644 --- a/src/gallium/winsys/amdgpu/drm/amdgpu_winsys.c +++ b/src/gallium/winsys/amdgpu/drm/amdgpu_winsys.c @@ -102,7 +102,7 @@ static bool do_winsys_init(struct amdgpu_winsys *ws, handle_env_var_force_family(ws); - ws->addrlib = amdgpu_addr_create(&ws->info, &ws->amdinfo, &ws->info.max_alignment); + ws->addrlib = ac_addrlib_create(&ws->info, &ws->amdinfo, &ws->info.max_alignment); if (!ws->addrlib) { fprintf(stderr, "amdgpu: Cannot create addrlib.\n"); goto fail; @@ -144,7 +144,7 @@ static void do_winsys_deinit(struct amdgpu_winsys *ws) simple_mtx_destroy(&ws->global_bo_list_lock); simple_mtx_destroy(&ws->bo_export_table_lock); - AddrDestroy(ws->addrlib); + ac_addrlib_destroy(ws->addrlib); amdgpu_device_deinitialize(ws->dev); FREE(ws); } diff --git a/src/gallium/winsys/amdgpu/drm/amdgpu_winsys.h b/src/gallium/winsys/amdgpu/drm/amdgpu_winsys.h index 7e677b517ff..42bc8846db5 100644 --- a/src/gallium/winsys/amdgpu/drm/amdgpu_winsys.h +++ b/src/gallium/winsys/amdgpu/drm/amdgpu_winsys.h @@ -31,7 +31,6 @@ #include "pipebuffer/pb_cache.h" #include "pipebuffer/pb_slab.h" #include "gallium/drivers/radeon/radeon_winsys.h" -#include "addrlib/inc/addrinterface.h" #include "util/simple_mtx.h" #include "util/u_queue.h" #include <amdgpu.h> @@ -79,7 +78,7 @@ struct amdgpu_winsys { struct util_queue cs_queue; struct amdgpu_gpu_info amdinfo; - ADDR_HANDLE addrlib; + struct ac_addrlib *addrlib; bool check_vm; bool debug_all_bos; |