From: David Heidelberg Date: Mon, 24 Nov 2014 23:38:07 +0000 (+0100) Subject: st/nine: return GetAvailableTextureMem in bytes as expected (v2) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=a99f31bced1ac5dfea9942bb37301a21c9a73189;p=mesa.git st/nine: return GetAvailableTextureMem in bytes as expected (v2) PIPE_CAP_VIDEO_MEMORY returns the amount of video memory in megabytes, so need to converted it to bytes. Fixed Warframe memory detection. v2: also prepare for cards with more than 4GB memory Cc: "10.4" Tested-by: Yaroslav Andrusyak Reviewed-by: Ilia Mirkin Reviewed-by: Axel Davy Signed-off-by: David Heidelberg --- diff --git a/src/gallium/state_trackers/nine/device9.c b/src/gallium/state_trackers/nine/device9.c index 66d5e667f8e..d48f47d5bd4 100644 --- a/src/gallium/state_trackers/nine/device9.c +++ b/src/gallium/state_trackers/nine/device9.c @@ -423,7 +423,11 @@ NineDevice9_TestCooperativeLevel( struct NineDevice9 *This ) UINT WINAPI NineDevice9_GetAvailableTextureMem( struct NineDevice9 *This ) { - return This->screen->get_param(This->screen, PIPE_CAP_VIDEO_MEMORY); + const unsigned mem = This->screen->get_param(This->screen, PIPE_CAP_VIDEO_MEMORY); + if (mem < 4096) + return mem << 20; + else + return UINT_MAX; } HRESULT WINAPI