woody-woodpacker/rsa/rsa.c

50 lines
1.3 KiB
C
Raw Normal View History

2024-02-15 20:26:40 +00:00
#include "rsa.h"
rsa_t rsa_init(size_t len, bigint_t *primes) {
2024-02-15 20:26:40 +00:00
rsa_t rsa;
2024-02-16 14:57:11 +00:00
printf("Generating two primes of length %d bits\n", RSA_BLOCK_SIZE / 2);
2024-02-17 23:46:21 +00:00
//printf("Generating p...\n");
rsa.p = bigint_prime(len / 2, primes);
2024-02-17 23:46:21 +00:00
printf("p = %lu\n", ((uint64_t)rsa.p.data[1] << 32) + (uint64_t)rsa.p.data[0]);
//printf("p = %u\n", rsa.p.data[0]);
//printf("Generating q...\n");
rsa.q = bigint_prime(len / 2, primes);
2024-02-17 23:46:21 +00:00
printf("q = %lu\n", ((uint64_t)rsa.q.data[1] << 32) + (uint64_t)rsa.q.data[0]);
//printf("q = %u\n", rsa.q.data[0]);
2024-02-16 14:57:11 +00:00
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;
bigint_t *primes = (bigint_t *)protected_malloc(3245 * sizeof(bigint_t));
for (int i = 0; i < 3245; i++) {
primes[i] = bigint_zero(len);
}
int fd = open("primes.0000", O_RDONLY);
char *buf = (char *)malloc(21290 * sizeof(char));
int ret = read(fd, buf, 21290);
char *tok = strtok(buf, "\n");
int i = 0;
while (tok) {
primes[i].data[0] = (uint32_t)atoi(tok);
tok = strtok(NULL, "\n");
i += 1;
}
printf("ret %d\n", ret);
rsa_t rsa = rsa_init(len, primes);
2024-02-17 23:46:21 +00:00
bigint_destroy(rsa.p);
bigint_destroy(rsa.q);
for (int i = 0; i < 18; i++) {
bigint_t p = bigint_prime(len / 2, primes);
2024-02-17 23:46:21 +00:00
printf("%lu\n", ((uint64_t)p.data[1] << 32) + (uint64_t)p.data[0]);
bigint_destroy(p);
}
2024-02-15 20:26:40 +00:00
return rsa;
}
2024-02-17 23:46:21 +00:00