00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034 #ifndef _RSAAUX_H
00035 #define _RSAAUX_H
00036
00037 #ifndef _RSADEF_H
00038 #include "rsadef.h"
00039 #endif
00040
00041 extern rsa_NUMBER a_one,a_two;
00042
00043
00044
00045
00046
00047 void a_add(rsa_NUMBER*, rsa_NUMBER*, rsa_NUMBER*);
00048 void a_assign(rsa_NUMBER*, rsa_NUMBER*);
00049 int a_cmp(rsa_NUMBER*, rsa_NUMBER*);
00050 void a_div(rsa_NUMBER*, rsa_NUMBER*, rsa_NUMBER*, rsa_NUMBER*);
00051 void a_div2(rsa_NUMBER*);
00052 void a_ggt(rsa_NUMBER*, rsa_NUMBER*, rsa_NUMBER*);
00053 void a_imult(rsa_NUMBER*, rsa_INT, rsa_NUMBER*);
00054 void a_mult(rsa_NUMBER*, rsa_NUMBER*, rsa_NUMBER*);
00055 void a_sub(rsa_NUMBER*, rsa_NUMBER*, rsa_NUMBER*);
00056 void m_init(rsa_NUMBER*, rsa_NUMBER*);
00057 void m_add(rsa_NUMBER*, rsa_NUMBER*, rsa_NUMBER*);
00058 void m_mult(rsa_NUMBER*, rsa_NUMBER*, rsa_NUMBER*);
00059 void m_exp(rsa_NUMBER*, rsa_NUMBER*, rsa_NUMBER*);
00060 int n_bits(rsa_NUMBER*, int);
00061 void n_div(rsa_NUMBER*, rsa_NUMBER*, rsa_NUMBER*, rsa_NUMBER*);
00062 int n_cmp(rsa_INT*, rsa_INT*, int);
00063 int n_mult(rsa_INT*, rsa_INT, rsa_INT*, int);
00064 int n_sub(rsa_INT*, rsa_INT*, rsa_INT*, int, int);
00065 int n_bitlen(rsa_NUMBER*);
00066
00067
00068
00069
00070
00071
00072
00073 int p_prim(rsa_NUMBER*, int);
00074 void inv(rsa_NUMBER*, rsa_NUMBER*, rsa_NUMBER*);
00075
00076
00077
00078
00079
00080
00081 void gen_number(int, rsa_NUMBER*);
00082 void init_rnd(void);
00083
00084
00085
00086
00087
00088
00089 void do_crypt(char *, char *, int, rsa_NUMBER *);
00090
00091
00092
00093
00094
00095
00096
00097
00098 #endif