forked from ANSSI-FR/libecc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathprj_pt.h
106 lines (76 loc) · 2.91 KB
/
prj_pt.h
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
/*
* Copyright (C) 2017 - This file is part of libecc project
*
* Authors:
* Ryad BENADJILA <ryadbenadjila@gmail.com>
* Arnaud EBALARD <arnaud.ebalard@ssi.gouv.fr>
* Jean-Pierre FLORI <jean-pierre.flori@ssi.gouv.fr>
*
* Contributors:
* Nicolas VIVET <nicolas.vivet@ssi.gouv.fr>
* Karim KHALFALLAH <karim.khalfallah@ssi.gouv.fr>
*
* This software is licensed under a dual BSD and GPL v2 license.
* See LICENSE file at the root folder of the project.
*/
#ifndef __PRJ_PT_H__
#define __PRJ_PT_H__
#include "../nn/nn_mul.h"
#include "../fp/fp.h"
#include "../fp/fp_mul.h"
#include "../fp/fp_mul_redc1.h"
#include "ec_shortw.h"
#include "aff_pt.h"
typedef struct {
fp X;
fp Y;
fp Z;
ec_shortw_crv_src_t crv;
word_t magic;
} prj_pt;
typedef prj_pt *prj_pt_t;
typedef const prj_pt *prj_pt_src_t;
void prj_pt_check_initialized(prj_pt_src_t in);
int prj_pt_is_initialized(prj_pt_src_t in);
void prj_pt_init(prj_pt_t in, ec_shortw_crv_src_t curve);
void prj_pt_init_from_coords(prj_pt_t in,
ec_shortw_crv_src_t curve,
fp_src_t xcoord,
fp_src_t ycoord, fp_src_t zcoord);
void prj_pt_uninit(prj_pt_t in);
void prj_pt_zero(prj_pt_t out);
int prj_pt_iszero(prj_pt_src_t in);
int prj_pt_is_on_curve(prj_pt_src_t in);
void prj_pt_copy(prj_pt_t out, prj_pt_src_t in);
void prj_pt_to_aff(aff_pt_t out, prj_pt_src_t in);
void prj_pt_unique(prj_pt_t out, prj_pt_src_t in);
void ec_shortw_aff_to_prj(prj_pt_t out, aff_pt_src_t in);
int prj_pt_cmp(prj_pt_src_t in1, prj_pt_src_t in2);
int prj_pt_eq_or_opp(prj_pt_src_t in1, prj_pt_src_t in2);
void prj_pt_neg(prj_pt_t out, prj_pt_src_t in);
int prj_pt_import_from_buf(prj_pt_t pt,
const u8 *pt_buf,
u16 pt_buf_len, ec_shortw_crv_src_t crv);
int prj_pt_import_from_aff_buf(prj_pt_t pt,
const u8 *pt_buf,
u16 pt_buf_len, ec_shortw_crv_src_t crv);
int prj_pt_export_to_buf(prj_pt_src_t pt, u8 *pt_buf, u32 pt_buf_len);
int prj_pt_export_to_aff_buf(prj_pt_src_t pt, u8 *pt_buf, u32 pt_buf_len);
void prj_pt_add(prj_pt_t sum, prj_pt_src_t in1, prj_pt_src_t in2);
void prj_pt_dbl(prj_pt_t dbl, prj_pt_src_t in);
void prj_pt_mul(prj_pt_t out, nn_src_t m, prj_pt_src_t in);
int prj_pt_mul_blind(prj_pt_t out, nn_src_t m, prj_pt_src_t in);
void aff_pt_edwards_to_prj_pt_shortw(aff_pt_edwards_src_t in_edwards,
ec_shortw_crv_src_t shortw_crv,
prj_pt_t out_shortw, fp_src_t alpha);
void aff_pt_montgomery_to_prj_pt_shortw(aff_pt_montgomery_src_t in_montgomery,
ec_shortw_crv_src_t shortw_crv,
prj_pt_t out_shortw);
void prj_pt_shortw_to_aff_pt_edwards(prj_pt_src_t in_shortw,
ec_edwards_crv_src_t edwards_crv,
aff_pt_edwards_t out_edwards,
fp_src_t alpha);
void prj_pt_shortw_to_aff_pt_montgomery(prj_pt_src_t in_shortw,
ec_montgomery_crv_src_t montgomery_crv,
aff_pt_montgomery_t out_montgomery);
#endif /* __PRJ_PT_H__ */