[Mesa-dev] [Mesa-stable] [PATCH 12/25] dri/i9*5: correctly calculate the amount of system memory

Ian Romanick idr at freedesktop.org
Sat Mar 1 08:47:56 PST 2014


On 02/28/2014 04:52 PM, Emil Velikov wrote:
> On 28/02/14 17:32, Ian Romanick wrote:
>> On 02/21/2014 07:04 PM, Emil Velikov wrote:
>>> The variable name states megabytes, while we calculate the amount in
>>> kilobytes. Correct this by dividing with the correct amount.
>>>
>>> Cc: "10.0 10.1" <mesa-stable at lists.freedesktop.org>
>>> Cc: Ian Romanick <ian.d.romanick at intel.com>
>>> Signed-off-by: Emil Velikov <emil.l.velikov at gmail.com>
>>> ---
>>>    src/mesa/drivers/dri/i915/intel_screen.c | 2 +-
>>>    src/mesa/drivers/dri/i965/intel_screen.c | 2 +-
>>>    2 files changed, 2 insertions(+), 2 deletions(-)
>>>
>>> diff --git a/src/mesa/drivers/dri/i915/intel_screen.c
>>> b/src/mesa/drivers/dri/i915/intel_screen.c
>>> index 296df16..884fdb5 100644
>>> --- a/src/mesa/drivers/dri/i915/intel_screen.c
>>> +++ b/src/mesa/drivers/dri/i915/intel_screen.c
>>> @@ -744,7 +744,7 @@ i915_query_renderer_integer(__DRIscreen *psp, int
>>> param, unsigned int *value)
>>>             * (uint64_t) system_page_size;
>>>
>>>          const unsigned system_memory_megabytes =
>>> -         (unsigned) (system_memory_bytes / 1024);
>>> +         (unsigned) (system_memory_bytes / (1024 * 1024));
>>
>> I don't think this is correct.  When I run piglit's
>> glx-query-renderer-coverage, it says
>>
>> glXQueryRendererIntegerMESA(GLX_RENDERER_VIDEO_MEMORY_MESA) values:
>>      1534
>>
>> That's 1.5GiB, and that's the value I expect.  I guess the variable
>> system_memory_bytes should be called system_memory_kbytes instead.
>>
>> I see you have similar code in other patches in the series.  Does
>> glx-query-renderer-coverage give sensible values in those drivers?
>>
> I can only test swrast (both classic and gallium, patches 11 and 24) and
> gallium nouveau. The former gives a sensible result for my 4GiB machine.
>
> glXQueryRendererIntegerMESA(GLX_RENDERER_VIDEO_MEMORY_MESA) values:
>      3957
>
>
> $ man sysconf
> PAGESIZE - _SC_PAGESIZE
>                Size of a page in bytes.
> _SC_PHYS_PAGES
>                The number of pages of physical memory.
>
> ... so I'm not sure how we get such a difference.
>
> Mind checking if the following gives reasonable result on your system ?
>
> printf("%ul\n", sysconf(_SC_PAGE_SIZE)*sysconf(_SC_PHYS_PAGES);

Seems right:

[idr at mumford-wire tmp]$ ./a.out ; head -1 /proc/meminfo
8085135360
MemTotal:        7895640 kB

But... your patch is correct.  The reason I get 1.5GiB is the first line 
not shown in the diff:

       value[0] = MIN2(system_memory_megabytes, gpu_mappable_megabytes);

Guess what gpu_mappable_megabytes is? :)

This patch is

Reviewed-by: Ian Romanick <ian.d.romanick at intel.com>

I'm going to push it now so that I can pick it to 10.1 for RC3.

> -Emil
>
> _______________________________________________
> mesa-stable mailing list
> mesa-stable at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/mesa-stable



More information about the mesa-dev mailing list