woody-woodpacker/rsa/rsa.c

45 lines
1.0 KiB
C
Raw Normal View History

2024-02-15 20:26:40 +00:00
#include "rsa.h"
rsa_t rsa_init(size_t len) {
rsa_t rsa;
2024-02-16 14:57:11 +00:00
printf("Generating two primes of length %d bits\n", RSA_BLOCK_SIZE / 2);
printf("Generating p...\n");
rsa.p = bigint_prime(len / 2);
printf("p = %u\n", rsa.p.data[0]);
printf("Generating q...\n");
rsa.q = bigint_prime(len / 2);
printf("q = %u\n", rsa.q.data[0]);
2024-02-15 20:26:40 +00:00
return rsa;
}
rsa_t rsa_generate_keys(size_t block_size) {
size_t len = block_size / sizeof(uint32_t) / 8;
rsa_t rsa = rsa_init(len);
bigint_t a = bigint_zero(4);
bigint_t b = bigint_zero(4);
a.data[0] = 1234567890;
b.data[0] = 234567;
bigint_t result = assignable_bigint_modulo(a, b);
printf("result is %ud\n", result.data[0]);
2024-02-16 14:57:11 +00:00
bigint_destroy(a);
2024-02-16 12:32:06 +00:00
a = bigint_clone(result);
b.data[0] = 5764;
printf("length\na: %lu e: %lu n: %lu\n", result.len, a.len, b.len);
bigint_t result2 = assignable_bigint_pow_mod(result, a, b);
2024-02-16 14:57:11 +00:00
bigint_destroy(a);
bigint_destroy(b);
bigint_destroy(result);
2024-02-16 12:32:06 +00:00
printf("bigpowmod is %u \n", result2.data[0]);
2024-02-16 14:57:11 +00:00
bigint_destroy(result2);
2024-02-15 20:26:40 +00:00
return rsa;
}