<html>
<head>
<base href="https://bugs.freedesktop.org/">
</head>
<body>
<p>
<div>
<b><a class="bz_bug_link
bz_status_RESOLVED bz_closed"
title="RESOLVED FIXED - Shader Disk Cache 32/64 bit detection has a flaw. Missed existence of x32 ABI"
href="https://bugs.freedesktop.org/show_bug.cgi?id=100073#c37">Comment # 37</a>
on <a class="bz_bug_link
bz_status_RESOLVED bz_closed"
title="RESOLVED FIXED - Shader Disk Cache 32/64 bit detection has a flaw. Missed existence of x32 ABI"
href="https://bugs.freedesktop.org/show_bug.cgi?id=100073">bug 100073</a>
from <span class="vcard"><a class="email" href="mailto:oiaohm@gmail.com" title="oiaohm@gmail.com">oiaohm@gmail.com</a>
</span></b>
<pre>(In reply to Marek Olšák from <a href="show_bug.cgi?id=100073#c36">comment #36</a>)
<span class="quote">> The build id and GPU id can be compared directly after the hash lookup and
> decompression to prevent collisions when two shaders with different IDs have
> the same hash. Thus we only have to worry about collisions between shaders
> having the same IDs.</span >
This read we will deal with a collisions instead of avoiding collisions by
using more cpu cycles every time a shader is loaded this does not sound
particularly good for performance.
Build-id and gpu-id could be directories in the cache. This would reduce the
number of entries you need to search for hits in and you would not find matches
with invalid values of build-id or gpu-id in the first place. This means you
could skip checking for those value when loading a shader from cache because
only the correct files should in those directories unless user has done
something stupid.
If build-id and gpu-id were directories cache cleaning would be simpler. Why
you could rm -rf the no longer required directories. This would still keep
file names fairly clean.
Marek Olšák is really valid to waste cpu cycles checking Build-id and Gpu-id
when it can be done once when opening the directory to search for cache
entries. I think not. So I don't think build-id and gpu-id mixed into hash
would be a good thing.
Build-id and gpu-id could be in the shader entries to detect if user has done
something bad to the cache with a audit tool but this is not something that has
to be run when a game is running. But you do have to be careful with build-id
like appending the build-id on the end of the file past the point the hash was
calculated to so that collision are consistent. Also keeping collision
possibilities consistent make it possible for application developers to work
around them if they ever happen.
Performance does mean worrying about wasting cycles. Reducing possibility of
collisions by design reduces how many cpu cycles you have to waste preventing
collision based errors. You really don't want to have to be doing any extra
checks every time you access the cache thinking a shader cache should be
reasonably heavily used at times.</pre>
</div>
</p>
<hr>
<span>You are receiving this mail because:</span>
<ul>
<li>You are the assignee for the bug.</li>
<li>You are the QA Contact for the bug.</li>
</ul>
</body>
</html>