/* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #ifndef __ecp_secp384r1_h_ #define __ecp_secp384r1_h_ /*- * Wrapper: simultaneous scalar mutiplication. * outx, outy := a * G + b * P * where P = (inx, iny). * Everything is LE byte ordering. */ void point_mul_two_secp384r1(unsigned char outx[48], unsigned char outy[48], const unsigned char a[48], const unsigned char b[48], const unsigned char inx[48], const unsigned char iny[48]); /*- * Wrapper: fixed scalar mutiplication. * outx, outy := scalar * G * Everything is LE byte ordering. */ void point_mul_g_secp384r1(unsigned char outx[48], unsigned char outy[48], const unsigned char scalar[48]); /*- * Wrapper: variable point scalar mutiplication. * outx, outy := scalar * P * where P = (inx, iny). * Everything is LE byte ordering. */ void point_mul_secp384r1(unsigned char outx[48], unsigned char outy[48], const unsigned char scalar[48], const unsigned char inx[48], const unsigned char iny[48]); #endif