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
|
/*
* Copyright (C) 2017 Denys Vlasenko
*
* Licensed under GPLv2, see file LICENSE in this source tree.
*
* Selected few declarations for RSA.
*/
typedef struct {
pstm_int e, d, N, qP, dP, dQ, p, q;
uint32 size; /* Size of the key in bytes */
int32 optimized; /* 1 for optimized */
//bbox psPool_t *pool;
} psRsaKey_t;
static ALWAYS_INLINE void psRsaKey_clear(psRsaKey_t *key)
{
pstm_clear(&key->N);
pstm_clear(&key->e);
pstm_clear(&key->d);
pstm_clear(&key->p);
pstm_clear(&key->q);
pstm_clear(&key->dP);
pstm_clear(&key->dQ);
pstm_clear(&key->qP);
}
#define psRsaEncryptPub(pool, key, in, inlen, out, outlen, data) \
psRsaEncryptPub( key, in, inlen, out, outlen)
int32 psRsaEncryptPub(psPool_t *pool, psRsaKey_t *key,
unsigned char *in, uint32 inlen,
unsigned char *out, uint32 outlen, void *data) FAST_FUNC;
|