]> git.cryptolib.org Git - avr-crypto-lib.git/blob - rsa/rsa.c
0281c7e18f741b2b5091145bff9e728424ef6f41
[avr-crypto-lib.git] / rsa / rsa.c
1 /* rsa_enc.c */
2 /*
3     This file is part of the AVR-Crypto-Lib.
4     Copyright (C) 2010 Daniel Otte (daniel.otte@rub.de)
5
6     This program is free software: you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation, either version 3 of the License, or
9     (at your option) any later version.
10
11     This program is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with this program.  If not, see <http://www.gnu.org/licenses/>.
18 */
19
20 #include <stdint.h>
21 #include "cli.h"
22 #include "bigint/bigint.h"
23 #include "rsa.h"
24
25 uint8_t rsa_enc_bigint(bigint_t* c, const bigint_t* m,
26                                 const rsa_ctx_t* ctx){
27         bigint_expmod_u(c, m, &(ctx->pubexp), &(ctx->modulus));
28         return 0;
29 }
30
31 uint8_t rsa_dec_bigint(bigint_t* m, const bigint_t* c,
32                                 const rsa_ctx_t* ctx){
33         bigint_expmod_u(m, c, &(ctx->privexp), &(ctx->modulus));
34         return 0;
35 }
36