forked from contrun/libecc
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathaff_pt.h
50 lines (43 loc) · 1.47 KB
/
aff_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
/*
* Copyright (C) 2017 - This file is part of libecc project
*
* Authors:
* Ryad BENADJILA <[email protected]>
* Arnaud EBALARD <[email protected]>
* Jean-Pierre FLORI <[email protected]>
*
* Contributors:
* Nicolas VIVET <[email protected]>
* Karim KHALFALLAH <[email protected]>
*
* This software is licensed under a dual BSD and GPL v2 license.
* See LICENSE file at the root folder of the project.
*/
#ifndef __AFF_PT_H__
#define __AFF_PT_H__
#include "../fp/fp.h"
#include "ec_shortw.h"
typedef struct {
fp x;
fp y;
ec_shortw_crv_src_t crv;
word_t magic;
} aff_pt;
typedef aff_pt *aff_pt_t;
typedef const aff_pt_t aff_pt_src_t;
void aff_pt_check_initialized(aff_pt_src_t in);
int aff_pt_is_initialized(aff_pt_src_t in);
void aff_pt_init(aff_pt_t in, ec_shortw_crv_src_t curve);
void aff_pt_init_from_coords(aff_pt_t in,
ec_shortw_crv_src_t curve,
fp_src_t xcoord, fp_src_t ycoord);
void aff_pt_uninit(aff_pt_t in);
int is_on_curve(fp_src_t x, fp_src_t y, ec_shortw_crv_src_t curve);
void ec_shortw_aff_copy(aff_pt_t out, aff_pt_src_t in);
int ec_shortw_aff_cmp(aff_pt_src_t in1, aff_pt_src_t in2);
int ec_shortw_aff_eq_or_opp(aff_pt_src_t in1, aff_pt_src_t in2);
int aff_pt_import_from_buf(aff_pt_t pt,
const u8 *pt_buf,
u16 pt_buf_len, ec_shortw_crv_src_t crv);
int aff_pt_export_to_buf(aff_pt_src_t pt, u8 *pt_buf, u32 pt_buf_len);
#endif /* __EC_SHORTW_AFF_PT_H__ */