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

org.bouncycastle.math.ec.rfc8032.ScalarUtil Maven / Gradle / Ivy

Go to download

The Bouncy Castle Crypto package is a Java implementation of cryptographic algorithms. This jar contains JCE provider and lightweight API for the Bouncy Castle Cryptography APIs for JDK 1.4.

There is a newer version: 1.79
Show newest version
package org.bouncycastle.math.ec.rfc8032;

import org.bouncycastle.util.Integers;

abstract class ScalarUtil
{
    private static final long M = 0xFFFFFFFFL;

    static void addShifted_NP(int last, int s, int[] Nu, int[] Nv, int[] p, int[] t)
    {
        long cc_p = 0L;
        long cc_Nu = 0L;

        if (s == 0)
        {
            for (int i = 0; i <= last; ++i)
            {
                int p_i = p[i];

                cc_Nu += Nu[i] & M;
                cc_Nu += p_i & M;

                cc_p += p_i & M;
                cc_p += Nv[i] & M;
                p_i   = (int)cc_p; cc_p >>>= 32;
                p[i]  = p_i;

                cc_Nu += p_i & M;
                Nu[i]  = (int)cc_Nu; cc_Nu >>>= 32;
            }
        }
        else if (s < 32)
        {
            int prev_p = 0;
            int prev_q = 0;
            int prev_v = 0;

            for (int i = 0; i <= last; ++i)
            {
                int p_i = p[i];
                int p_s = (p_i << s) | (prev_p >>> -s);
                prev_p = p_i;

                cc_Nu += Nu[i] & M;
                cc_Nu += p_s & M;

                int next_v = Nv[i];
                int v_s = (next_v << s) | (prev_v >>> -s);
                prev_v = next_v;

                cc_p += p_i & M;
                cc_p += v_s & M;
                p_i   = (int)cc_p; cc_p >>>= 32;
                p[i]  = p_i;

                int q_s = (p_i << s) | (prev_q >>> -s);
                prev_q = p_i;

                cc_Nu += q_s & M;
                Nu[i]  = (int)cc_Nu; cc_Nu >>>= 32;
            }
        }
        else
        {
            // Copy the low limbs of the original p
            System.arraycopy(p, 0, t, 0, last);

            int sWords = s >>> 5; int sBits = s & 31;
            if (sBits == 0)
            {
                for (int i = sWords; i <= last; ++i)
                {
                    cc_Nu += Nu[i] & M;
                    cc_Nu += t[i - sWords] & M;

                    cc_p += p[i] & M;
                    cc_p += Nv[i - sWords] & M;
                    p[i]  = (int)cc_p; cc_p >>>= 32;

                    cc_Nu += p[i - sWords] & M;
                    Nu[i]  = (int)cc_Nu; cc_Nu >>>= 32;
                }
            }
            else
            {
                int prev_t = 0;
                int prev_q = 0;
                int prev_v = 0;

                for (int i = sWords; i <= last; ++i)
                {
                    int next_t = t[i - sWords];
                    int t_s = (next_t << sBits) | (prev_t >>> -sBits);
                    prev_t = next_t;

                    cc_Nu += Nu[i] & M;
                    cc_Nu += t_s & M;

                    int next_v = Nv[i - sWords];
                    int v_s = (next_v << sBits) | (prev_v >>> -sBits);
                    prev_v = next_v;

                    cc_p += p[i] & M;
                    cc_p += v_s & M;
                    p[i]  = (int)cc_p; cc_p >>>= 32;

                    int next_q = p[i - sWords];
                    int q_s = (next_q << sBits) | (prev_q >>> -sBits);
                    prev_q = next_q;

                    cc_Nu += q_s & M;
                    Nu[i]  = (int)cc_Nu; cc_Nu >>>= 32;
                }
            }
        }
    }

    static void addShifted_UV(int last, int s, int[] u0, int[] u1, int[] v0, int[] v1)
    {
        int sWords = s >>> 5, sBits = s & 31;

        long cc_u0 = 0L;
        long cc_u1 = 0L;

        if (sBits == 0)
        {
            for (int i = sWords; i <= last; ++i)
            {
                cc_u0 += u0[i] & M;
                cc_u1 += u1[i] & M;
                cc_u0 += v0[i - sWords] & M;
                cc_u1 += v1[i - sWords] & M;
                u0[i]  = (int)cc_u0; cc_u0 >>>= 32;
                u1[i]  = (int)cc_u1; cc_u1 >>>= 32;
            }
        }
        else
        {
            int prev_v0 = 0;
            int prev_v1 = 0;

            for (int i = sWords; i <= last; ++i)
            {
                int next_v0 = v0[i - sWords];
                int next_v1 = v1[i - sWords];
                int v0_s = (next_v0 << sBits) | (prev_v0 >>> -sBits);
                int v1_s = (next_v1 << sBits) | (prev_v1 >>> -sBits);
                prev_v0 = next_v0;
                prev_v1 = next_v1;

                cc_u0 += u0[i] & M;
                cc_u1 += u1[i] & M;
                cc_u0 += v0_s & M;
                cc_u1 += v1_s & M;
                u0[i]  = (int)cc_u0; cc_u0 >>>= 32;
                u1[i]  = (int)cc_u1; cc_u1 >>>= 32;
            }
        }
    }

    static int getBitLength(int last, int[] x)
    {
        int i = last;
        int sign = x[i] >> 31;
        while (i > 0 && x[i] == sign)
        {
            --i;
        }
        return i * 32 + 32 - Integers.numberOfLeadingZeros(x[i] ^ sign);
    }

    static int getBitLengthPositive(int last, int[] x)
    {
        int i = last;
        while (i > 0 && x[i] == 0)
        {
            --i;
        }
        return i * 32 + 32 - Integers.numberOfLeadingZeros(x[i]);
    }

    static boolean lessThan(int last, int[] x, int[] y)
    {
        int i = last;
        do
        {
            int x_i = x[i] + Integer.MIN_VALUE;
            int y_i = y[i] + Integer.MIN_VALUE;
            if (x_i < y_i)
                return true;
            if (x_i > y_i)
                return false;
        }
        while (--i >= 0);
        return false;
    }

    static void subShifted_NP(int last, int s, int[] Nu, int[] Nv, int[] p, int[] t)
    {
        long cc_p = 0L;
        long cc_Nu = 0L;

        if (s == 0)
        {
            for (int i = 0; i <= last; ++i)
            {
                int p_i = p[i];

                cc_Nu += Nu[i] & M;
                cc_Nu -= p_i & M;

                cc_p += p_i & M;
                cc_p -= Nv[i] & M;
                p_i   = (int)cc_p; cc_p >>= 32;
                p[i]  = p_i;

                cc_Nu -= p_i & M;
                Nu[i]  = (int)cc_Nu; cc_Nu >>= 32;
            }
        }
        else if (s < 32)
        {
            int prev_p = 0;
            int prev_q = 0;
            int prev_v = 0;

            for (int i = 0; i <= last; ++i)
            {
                int p_i = p[i];
                int p_s = (p_i << s) | (prev_p >>> -s);
                prev_p = p_i;

                cc_Nu += Nu[i] & M;
                cc_Nu -= p_s & M;

                int next_v = Nv[i];
                int v_s = (next_v << s) | (prev_v >>> -s);
                prev_v = next_v;

                cc_p += p_i & M;
                cc_p -= v_s & M;
                p_i   = (int)cc_p; cc_p >>= 32;
                p[i]  = p_i;

                int q_s = (p_i << s) | (prev_q >>> -s);
                prev_q = p_i;

                cc_Nu -= q_s & M;
                Nu[i]  = (int)cc_Nu; cc_Nu >>= 32;
            }
        }
        else
        {
            // Copy the low limbs of the original p
            System.arraycopy(p, 0, t, 0, last);

            int sWords = s >>> 5; int sBits = s & 31;
            if (sBits == 0)
            {
                for (int i = sWords; i <= last; ++i)
                {
                    cc_Nu += Nu[i] & M;
                    cc_Nu -= t[i - sWords] & M;

                    cc_p += p[i] & M;
                    cc_p -= Nv[i - sWords] & M;
                    p[i]  = (int)cc_p; cc_p >>= 32;

                    cc_Nu -= p[i - sWords] & M;
                    Nu[i]  = (int)cc_Nu; cc_Nu >>= 32;
                }
            }
            else
            {
                int prev_t = 0;
                int prev_q = 0;
                int prev_v = 0;

                for (int i = sWords; i <= last; ++i)
                {
                    int next_t = t[i - sWords];
                    int t_s = (next_t << sBits) | (prev_t >>> -sBits);
                    prev_t = next_t;

                    cc_Nu += Nu[i] & M;
                    cc_Nu -= t_s & M;

                    int next_v = Nv[i - sWords];
                    int v_s = (next_v << sBits) | (prev_v >>> -sBits);
                    prev_v = next_v;

                    cc_p += p[i] & M;
                    cc_p -= v_s & M;
                    p[i]  = (int)cc_p; cc_p >>= 32;

                    int next_q = p[i - sWords];
                    int q_s = (next_q << sBits) | (prev_q >>> -sBits);
                    prev_q = next_q;

                    cc_Nu -= q_s & M;
                    Nu[i]  = (int)cc_Nu; cc_Nu >>= 32;
                }
            }
        }
    }

    static void subShifted_UV(int last, int s, int[] u0, int[] u1, int[] v0, int[] v1)
    {
        int sWords = s >>> 5, sBits = s & 31;

        long cc_u0 = 0L;
        long cc_u1 = 0L;

        if (sBits == 0)
        {
            for (int i = sWords; i <= last; ++i)
            {
                cc_u0 += u0[i] & M;
                cc_u1 += u1[i] & M;
                cc_u0 -= v0[i - sWords] & M;
                cc_u1 -= v1[i - sWords] & M;
                u0[i]  = (int)cc_u0; cc_u0 >>= 32;
                u1[i]  = (int)cc_u1; cc_u1 >>= 32;
            }
        }
        else
        {
            int prev_v0 = 0;
            int prev_v1 = 0;

            for (int i = sWords; i <= last; ++i)
            {
                int next_v0 = v0[i - sWords];
                int next_v1 = v1[i - sWords];
                int v0_s = (next_v0 << sBits) | (prev_v0 >>> -sBits);
                int v1_s = (next_v1 << sBits) | (prev_v1 >>> -sBits);
                prev_v0 = next_v0;
                prev_v1 = next_v1;

                cc_u0 += u0[i] & M;
                cc_u1 += u1[i] & M;
                cc_u0 -= v0_s & M;
                cc_u1 -= v1_s & M;
                u0[i]  = (int)cc_u0; cc_u0 >>= 32;
                u1[i]  = (int)cc_u1; cc_u1 >>= 32;
            }
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy