2018-10-06 20:37:09 -07:00
|
|
|
#pragma once
|
2017-01-03 02:32:39 -08:00
|
|
|
|
|
|
|
#include "athena/Types.hpp"
|
2018-12-07 21:18:17 -08:00
|
|
|
namespace bignum {
|
2017-01-03 02:32:39 -08:00
|
|
|
int compare(const atUint8* a, const atUint8* b, atUint32 n);
|
|
|
|
void subModulus(atUint8* a, const atUint8* N, atUint32 n);
|
|
|
|
void add(atUint8* d, atUint8* a, const atUint8* b, const atUint8* N, atUint32 n);
|
|
|
|
void mul(atUint8* d, atUint8* a, const atUint8* b, const atUint8* N, atUint32 n);
|
|
|
|
void exp(atUint8* d, const atUint8* a, const atUint8* N, atUint32 n, atUint8* e, atUint32 en);
|
|
|
|
void inv(atUint8* d, atUint8* a, const atUint8* N, atUint32 n);
|
2018-12-07 21:18:17 -08:00
|
|
|
} // namespace bignum
|