1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17#ifndef G10_MPI_H
18#define G10_MPI_H
19
20#include <linux/types.h>
21#include <linux/scatterlist.h>
22
23#define BYTES_PER_MPI_LIMB (BITS_PER_LONG / 8)
24#define BITS_PER_MPI_LIMB BITS_PER_LONG
25
26typedef unsigned long int mpi_limb_t;
27typedef signed long int mpi_limb_signed_t;
28
29struct gcry_mpi {
30 int alloced;
31 int nlimbs;
32 int nbits;
33 int sign;
34 unsigned flags;
35
36
37 mpi_limb_t *d;
38};
39
40typedef struct gcry_mpi *MPI;
41
42#define mpi_get_nlimbs(a) ((a)->nlimbs)
43
44
45MPI mpi_alloc(unsigned nlimbs);
46void mpi_free(MPI a);
47int mpi_resize(MPI a, unsigned nlimbs);
48
49
50MPI mpi_read_raw_data(const void *xbuffer, size_t nbytes);
51MPI mpi_read_from_buffer(const void *buffer, unsigned *ret_nread);
52MPI mpi_read_raw_from_sgl(struct scatterlist *sgl, unsigned int len);
53void *mpi_get_buffer(MPI a, unsigned *nbytes, int *sign);
54int mpi_read_buffer(MPI a, uint8_t *buf, unsigned buf_len, unsigned *nbytes,
55 int *sign);
56int mpi_write_to_sgl(MPI a, struct scatterlist *sg, unsigned nbytes,
57 int *sign);
58
59
60int mpi_powm(MPI res, MPI base, MPI exp, MPI mod);
61
62
63int mpi_cmp_ui(MPI u, ulong v);
64int mpi_cmp(MPI u, MPI v);
65
66
67void mpi_normalize(MPI a);
68unsigned mpi_get_nbits(MPI a);
69
70
71
72
73
74
75
76
77
78
79static inline unsigned int mpi_get_size(MPI a)
80{
81 return a->nlimbs * BYTES_PER_MPI_LIMB;
82}
83#endif
84