<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#c35">Comment # 35</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#c34">comment #34</a>)
<span class="quote">> Your argument for keeping the GPU and build IDs out of the hash because of
> the possibility of collisions has one flaw: The probability of a collision
> doesn't grow when the cache is already full (if the number of items in the
> cache remains the same).</span >

Sorry Marek you have your maths wrong you have missed something important
predictability of collisions.

The build_id particularly.  As this is a changing value.  When you put this in
the hash this does increase the risk of a collision not detected in program
development.

So you tested program with X build version no collisions in the hashes.   That
you merge build-id into sha the program is running with Y build version and now
due to insane bad luck the Y build-id value being different has caused a
collision that the programmer who made the program has no clue about.   So now
users using Y version are reporting problems that developer does not have and
is left totally confused.

So possibility of collisions has barely changed by merging build-id into hash. 
But how predictable a collision will be has changed massively.   Yet you still
see people making these arguments without the mathematics behind it.   
Predictability of when a collision is going to happen has altered massively by
merging the build-id so making collisions a lot more of a random event to
debug.

Reality you should avoid throwing changing values into hashes where you can as
this adds extra level of unpredictability.  With new optimisations to in ways
shaders are generated there is enough risk of collisions without making them
unpredictable.

gpu-id are less likely to be a cause and should be testable for by a developer.

Basically it bad enough to have a collision without giving it a
pseudorandomness factor.   I should have been more clear what I meant by
altering risk.   Altering risk for those attempting to provide working programs
to end users.   Making collision pseudorandom is not a useful feature not
helpful to those making programs.   A predictable hash collision developer of
program could possibly work around by not making anything that does that.

So please do remember hash collision have two factors.  Possibility and
Predictability.  A good hash solution for a cache decreases the possibility of
collision without being insanely unpredictable in case of collision if it ever
happens.  If you only look at Possibility you complete end up creating yourself
the worse cases if hash collision does happen.

<span class="quote">> It's a bad idea to wipe the cache on a driver or GPU switch, because DRI PRIME
> (hybrid graphics) switches between 2 GPUs all the time.</span >

I agree with this.  Its also a bad idea not to be able to clean cache when a
GPU is removed for good.   This is the main reason why I suggest keeping the
gpu-id exposed not hidden in a hash.

Also not being able to clean out items out of the cache for build_id or gpu_id
you are no longer using also increases risk of a collision version to version.

Design a system to clean the cache is just as important as making the cache.  
Yes wiping the cache on driver change is over cleaning.   Under cleaning is
also bad.   The issue is getting the right balance.</pre>
        </div>
      </p>


      <hr>
      <span>You are receiving this mail because:</span>

      <ul>
          <li>You are the QA Contact for the bug.</li>
          <li>You are the assignee for the bug.</li>
      </ul>
    </body>
</html>