diff --git a/src/amd/common/ac_surface.c b/src/amd/common/ac_surface.c index 7d21f817f7a..58348a02698 100644 --- a/src/amd/common/ac_surface.c +++ b/src/amd/common/ac_surface.c @@ -93,6 +93,7 @@ struct ac_addrlib { ADDR_HANDLE handle; + simple_mtx_t lock; }; bool ac_modifier_has_dcc(uint64_t modifier) @@ -503,11 +504,13 @@ struct ac_addrlib *ac_addrlib_create(const struct radeon_info *info, } addrlib->handle = addrCreateOutput.hLib; + simple_mtx_init(&addrlib->lock, mtx_plain); return addrlib; } void ac_addrlib_destroy(struct ac_addrlib *addrlib) { + simple_mtx_destroy(&addrlib->lock); AddrDestroy(addrlib->handle); free(addrlib); } @@ -1829,7 +1832,12 @@ static int gfx9_compute_miptree(struct ac_addrlib *addrlib, const struct radeon_ din.dataSurfaceSize = out.surfSize; din.firstMipIdInTail = out.firstMipIdInTail; + if (info->chip_class == GFX9) + simple_mtx_lock(&addrlib->lock); ret = Addr2ComputeDccInfo(addrlib->handle, &din, &dout); + if (info->chip_class == GFX9) + simple_mtx_unlock(&addrlib->lock); + if (ret != ADDR_OK) return ret; @@ -1910,7 +1918,12 @@ static int gfx9_compute_miptree(struct ac_addrlib *addrlib, const struct radeon_ assert(surf->tile_swizzle == 0); assert(surf->u.gfx9.color.dcc.pipe_aligned || surf->u.gfx9.color.dcc.rb_aligned); + if (info->chip_class == GFX9) + simple_mtx_lock(&addrlib->lock); ret = Addr2ComputeDccInfo(addrlib->handle, &din, &dout); + if (info->chip_class == GFX9) + simple_mtx_unlock(&addrlib->lock); + if (ret != ADDR_OK) return ret; @@ -2010,7 +2023,12 @@ static int gfx9_compute_miptree(struct ac_addrlib *addrlib, const struct radeon_ else cin.swizzleMode = in->swizzleMode; + if (info->chip_class == GFX9) + simple_mtx_lock(&addrlib->lock); ret = Addr2ComputeCmaskInfo(addrlib->handle, &cin, &cout); + if (info->chip_class == GFX9) + simple_mtx_unlock(&addrlib->lock); + if (ret != ADDR_OK) return ret;