1 Star 0 Fork 34

duapple/RSA

forked from Chuck/RSA 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
prime.c 2.67 KB
一键复制 编辑 原始数据 按行查看 历史
Chuck 提交于 2018-01-19 23:44 . Initial commit
/*****************************************************************************
Filename: prime.c
Author : Chuck Li (lch0821@foxmail.com)
Date : 2018-01-19 18:03:26
Description:
*****************************************************************************/
#include <string.h>
#include <stdlib.h>
#include <time.h>
#include "prime.h"
#include "rsa.h"
const uint8_t SMALL_PRIMES[] = {3, 5, 7, 11};
#define SMALL_PRIME_COUNT 4
static int probable_prime(bn_t *a, uint32_t digits);
static int small_factor(bn_t *a, uint32_t digits);
static int fermat_test(bn_t *a, uint32_t digits);
void initialize_rand(void)
{
srand((unsigned)time(NULL));
}
void generate_rand(uint8_t *block, uint32_t block_len)
{
uint32_t i;
for(i=0; i<block_len; i++) {
block[i] = rand();
}
}
int generate_prime(bn_t *a, bn_t *lower, bn_t *upper, bn_t *d, uint32_t digits)
{
uint8_t block[BN_MAX_DIGITS*BN_DIGIT_LEN];
bn_t t[BN_MAX_DIGITS], u[BN_MAX_DIGITS];
generate_rand(block, digits*BN_DIGIT_LEN);
bn_decode(a, digits, block, digits*BN_DIGIT_LEN);
bn_sub(t, upper, lower, digits);
BN_ASSIGN_DIGIT(u, 1, digits);
bn_add(t, t, u, digits);
bn_mod(a, a, digits, t, digits);
bn_add(a, a, lower, digits);
bn_mod(t, a, digits, d, digits);
bn_sub(a, a, t, digits);
bn_add(a, a, u, digits);
if(bn_cmp(a, lower, digits) < 0) {
bn_add(a, a, d, digits);
}
if(bn_cmp(a, upper, digits) > 0) {
bn_sub(a, a, d, digits);
}
bn_assign(t, upper, digits);
bn_sub(t, t, d, digits);
while(!probable_prime(a, digits)) {
if(bn_cmp(a, t, digits) > 0) {
return ERR_WRONG_DATA;
}
bn_add(a, a, d, digits);
}
return 0;
}
static int probable_prime(bn_t *a, uint32_t digits)
{
return (!small_factor(a, digits) && fermat_test(a, digits));
}
static int small_factor(bn_t *a, uint32_t digits)
{
int status;
bn_t t[1];
uint32_t i;
status = 0;
for(i=0; i<SMALL_PRIME_COUNT; i++) {
BN_ASSIGN_DIGIT(t, SMALL_PRIMES[i], 1);
if((digits == 1) && BN_EQUAL(a, t, 1)) {
break;
}
bn_mod(t, a, digits, t, 1);
if(bn_is_zero(t, 1)) {
status = 1;
break;
}
}
// Clear potentially sensitive information
i = 0;
memset((uint8_t *)t, 0, sizeof(t));
return status;
}
static int fermat_test(bn_t *a, uint32_t digits)
{
int status;
bn_t t[BN_MAX_DIGITS], u[BN_MAX_DIGITS];
BN_ASSIGN_DIGIT(t, 2, digits);
bn_mod_exp(u, t, a, digits, a, digits);
status = BN_EQUAL(t, u, digits);
// Clear potentially sensitive information
memset((uint8_t *)u, 0, sizeof(u));
return status;
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C
1
https://gitee.com/duapple/RSA.git
git@gitee.com:duapple/RSA.git
duapple
RSA
RSA
master

搜索帮助