prime.c

来自「文件驱动加密,功能强大,可产生加密分区,支持AES,MD2,MD4,MD5MD2」· C语言 代码 · 共 81 行

C
81
字号
/* LibTomCrypt, modular cryptographic library -- Tom St Denis * * LibTomCrypt is a library that provides various cryptographic * algorithms in a highly modular and flexible manner. * * The library is free for all purposes without any express * gurantee it works. * * Tom St Denis, tomstdenis@iahu.ca, http://libtomcrypt.org */#include "mycrypt.h"#ifdef MPIstruct rng_data {   prng_state *prng;   int         wprng;};#define UPPER_LIMIT    PRIME_SIZE/* figures out if a number is prime (MR test) */int is_prime(mp_int *N, int *result){   int err;   _ARGCHK(N != NULL);   _ARGCHK(result != NULL);   if ((err = mp_prime_is_prime(N, mp_prime_rabin_miller_trials(mp_count_bits(N)), result)) != MP_OKAY) {      return mpi_to_ltc_error(err);   }   return CRYPT_OK;}static int rand_prime_helper(unsigned char *dst, int len, void *dat){   return (int)prng_descriptor[((struct rng_data *)dat)->wprng].read(dst, len, ((struct rng_data *)dat)->prng);}int rand_prime(mp_int *N, long len, prng_state *prng, int wprng){   struct rng_data rng;   int             type, err;   _ARGCHK(N != NULL);   /* allow sizes between 2 and 256 bytes for a prime size */   if (len < 2 || len > 256) {       return CRYPT_INVALID_PRIME_SIZE;   }      /* valid PRNG? Better be! */   if ((err = prng_is_valid(wprng)) != CRYPT_OK) {      return err;    }   /* setup our callback data, then world domination! */   rng.prng  = prng;   rng.wprng = wprng;   /* get type */   if (len < 0) {      type = 1;      len = -len;   } else {      type = 0;   }   /* New prime generation makes the code even more cryptoish-insane.  Do you know what this means!!!      -- Gir:  Yeah, oh wait, er, no.    */   if ((err = mp_prime_random(N, mp_prime_rabin_miller_trials(len*8), len, type, rand_prime_helper, &rng)) != MP_OKAY) {      return mpi_to_ltc_error(err);   }   return CRYPT_OK;}      #endif

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?