1
0
mirror of http://galexander.org/git/simplesshd.git synced 2025-01-04 04:00:55 +00:00
simplesshd/dropbear/ecc.h

36 lines
1.1 KiB
C
Raw Normal View History

2019-06-09 20:44:26 +00:00
#ifndef DROPBEAR_DROPBEAR_ECC_H
#define DROPBEAR_DROPBEAR_ECC_H
2014-12-10 21:56:49 +00:00
#include "includes.h"
#include "buffer.h"
2019-06-09 20:44:26 +00:00
#if DROPBEAR_ECC
2014-12-10 21:56:49 +00:00
struct dropbear_ecc_curve {
int ltc_size; /* to match the byte sizes in ltc_ecc_sets[] */
const ltc_ecc_set_type *dp; /* curve domain parameters */
const struct ltc_hash_descriptor *hash_desc;
2019-06-09 20:44:26 +00:00
const char *name;
2014-12-10 21:56:49 +00:00
};
extern struct dropbear_ecc_curve ecc_curve_nistp256;
extern struct dropbear_ecc_curve ecc_curve_nistp384;
extern struct dropbear_ecc_curve ecc_curve_nistp521;
extern struct dropbear_ecc_curve *dropbear_ecc_curves[];
2019-06-09 20:44:26 +00:00
void dropbear_ecc_fill_dp(void);
2014-12-10 21:56:49 +00:00
struct dropbear_ecc_curve* curve_for_dp(const ltc_ecc_set_type *dp);
/* "pubkey" refers to a point, but LTC uses ecc_key structure for both public
and private keys */
void buf_put_ecc_raw_pubkey_string(buffer *buf, ecc_key *key);
ecc_key * buf_get_ecc_raw_pubkey(buffer *buf, const struct dropbear_ecc_curve *curve);
int buf_get_ecc_privkey_string(buffer *buf, ecc_key *key);
2019-06-09 20:44:26 +00:00
mp_int * dropbear_ecc_shared_secret(ecc_key *pub_key, const ecc_key *priv_key);
2014-12-10 21:56:49 +00:00
#endif
2019-06-09 20:44:26 +00:00
#endif /* DROPBEAR_DROPBEAR_ECC_H */