blob: 97fd326a281dda3b5af423adc7a17c5f049977f1 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
/*
* (C) 2018 Jack Lloyd
*
* Botan is released under the Simplified BSD License (see license.txt)
*/
#ifndef BOTAN_POINT_MUL_H_
#define BOTAN_POINT_MUL_H_
#include <botan/point_gfp.h>
namespace Botan {
static const size_t PointGFp_SCALAR_BLINDING_BITS = 80;
class PointGFp_Base_Point_Precompute
{
public:
PointGFp_Base_Point_Precompute(const PointGFp& base_point);
PointGFp mul(const BigInt& k,
RandomNumberGenerator& rng,
const BigInt& group_order,
std::vector<BigInt>& ws) const;
private:
std::vector<PointGFp> m_T;
};
class PointGFp_Var_Point_Precompute
{
public:
PointGFp_Var_Point_Precompute(const PointGFp& point);
void randomize_repr(RandomNumberGenerator& rng);
PointGFp mul(const BigInt& k,
RandomNumberGenerator& rng,
const BigInt& group_order,
std::vector<BigInt>& ws) const;
private:
size_t m_window_bits;
std::vector<PointGFp> m_U;
};
}
#endif
|