All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.bouncycastle.crypto.modes.kgcm.Tables4kKGCMMultiplier_128 Maven / Gradle / Ivy

package org.bouncycastle.crypto.modes.kgcm;

public class Tables4kKGCMMultiplier_128
    implements KGCMMultiplier
{
    private long[][] T;

    public void init(long[] H)
    {
        if (T == null)
        {
            T = new long[256][KGCMUtil_128.SIZE];
        }
        else if (KGCMUtil_128.equal(H, T[1]))
        {
            return;
        }

        // T[0] = 0

        // T[1] = H
        KGCMUtil_128.copy(H, T[1]);

        for (int n = 2; n < 256; n += 2)
        {
            // T[2.n] = x.T[n]
            KGCMUtil_128.multiplyX(T[n >> 1], T[n]);

            // T[2.n + 1] = T[2.n] + T[1]
            KGCMUtil_128.add(T[n], T[1], T[n + 1]);
        }
    }

    public void multiplyH(long[] z)
    {
        long[] r = new long[KGCMUtil_128.SIZE];
        KGCMUtil_128.copy(T[(int)(z[KGCMUtil_128.SIZE - 1] >>> 56) & 0xFF], r);
        for (int i = (KGCMUtil_128.SIZE << 3) - 2; i >= 0; --i)
        {
            KGCMUtil_128.multiplyX8(r, r);
            KGCMUtil_128.add(T[(int)(z[i >>> 3] >>> ((i & 7) << 3)) & 0xFF], r, r);
        }
        KGCMUtil_128.copy(r, z);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy