亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? rsakgtype.c

?? IBE是一種非對稱密碼技術
?? C
字號:
/* Copyright 2005-2006, Voltage Security, all rights reserved.
 */
#include "vibecrypto.h"
#include "environment.h"
#include "base.h"
#include "libctx.h"
#include "keyobj.h"
#include "rsa.h"
#include "mpint.h"
#include "random.h"
#include "errorctx.h"

/* This routine does the work. It allocates and fills in the contexts.
 *
 * @param obj The algorithm object to set.
 * @param keyGenInfo Contains the modLen and pubExpo.
 * @return an int, 0 if the function completed successfully or a
 * non-zero error code.
 */
static int VOLT_CALLING_CONV SetObjectRSAKeyGen VOLT_PROTO_LIST ((
   VoltKeyObject *obj,
   VoltRSAKeyPairGenInfo *keyGenInfo
));

int VtKeyPairGenRSA (
   VtKeyObject object,
   Pointer info,
   unsigned int flag,
   VtRandomObject random
   )
{
  int status;
  VoltKeyObject *obj = (VoltKeyObject *)object;
  VtRSAKeyPairGenInfo *genInfo;
  VoltRSAKeyPairGenInfo keyGenInfo;
  unsigned char pubExpo[3] = { 0x01, 0x00, 0x01 };
  VOLT_DECLARE_ERROR_TYPE (errorType)
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  do
  {
    /* Check the flag, it should be VOLT_KEY_SET_TYPE_FLAG.
     */
    VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_TYPE;
    if (flag != VOLT_KEY_SET_TYPE_FLAG)
      break;

    /* Check the keyType of the object. It should be 0.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_SET;
    if (obj->keyType != 0)
      break;

    /* The associated info should be a pointer to an unsigned int, the
     * modulus length, in bytes. The modulus must be 1024 or 2048 bits.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_ASSOCIATED_INFO;
    if (info == (Pointer)0)
      break;

    genInfo = (VtRSAKeyPairGenInfo *)info;

    keyGenInfo.modLenBits = genInfo->modulusBits;
    keyGenInfo.usageFlag = genInfo->usageFlag;
    keyGenInfo.pubExpo.data = pubExpo;
    keyGenInfo.pubExpo.len = 3;

    VOLT_SET_FNCT_LINE (fnctLine)
    if ( (keyGenInfo.modLenBits != 1024) &&
         (keyGenInfo.modLenBits != 2048) )
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    if ( (keyGenInfo.usageFlag != VT_RSA_KEY_USAGE_SIGN_VERIFY) &&
         (keyGenInfo.usageFlag != VT_RSA_KEY_USAGE_ENCRYPT_DECRYPT) )
      break;

    VOLT_SET_ERROR_TYPE (errorType, 0)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = SetObjectRSAKeyGen (obj, &keyGenInfo);

  } while (0);

  /* If everything worked, return 0.
   */
  if (status == 0)
  {
    /* Set the FIPS bit in the object type, this object is a FIPS
     * object.
     */
    obj->voltObject.objectType |= VOLT_OBJECT_TYPE_FIPS;
    return (0);
  }

  /* If something went wrong, indicate that this object is not usable.
   */
  obj->keyType = 0;

  VOLT_LOG_ERROR_INFO (
    0, obj, status, 0, errorType,
    (char *)0, "VtKeyPairGenRSA", fnctLine, (char *)0)

  return (status);
}

static int SetObjectRSAKeyGen (
   VoltKeyObject *obj,
   VoltRSAKeyPairGenInfo *keyGenInfo
   )
{
  int status;
  unsigned int bufferSize, modLen, prime1Len, prime2Len;
  unsigned char *buffer = (unsigned char *)0;
  VoltLibCtx *libCtx = (VoltLibCtx *)(obj->voltObject.libraryCtx);
  VoltRsaKeyGenCtx *rsaGenCtx;
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  do
  {
    /* This function assumes the modLenBits is a multiple of 16 (such
     * as 1024 or 2048).
     */
    prime1Len = keyGenInfo->modLenBits / 16;
    prime2Len = prime1Len;
    modLen = keyGenInfo->modLenBits / 8;

    /* Allocate enough space for an RsaKeyGenCtx. The buffers after the
     * struct will be byte arrays, so no need to worry about alignment.
     * These buffers will contain the primes, prime exponents, CRT
     * coefficient, pubExpo, priExpo, and modulus.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_MEMORY;
    bufferSize =
      sizeof (VoltRsaKeyGenCtx) + (3 * prime1Len) + (2 * prime2Len) +
      (2 * modLen) + keyGenInfo->pubExpo.len;
    buffer = (unsigned char *)Z2Malloc (bufferSize, VOLT_MEMORY_SENSITIVE);
    if (buffer == (unsigned char *)0)
      break;
    Z2Memset (buffer, 0, bufferSize);

    /* Locate the context.
     */
    rsaGenCtx = (VoltRsaKeyGenCtx *)buffer;

    /* Populate the context.
     */
    rsaGenCtx->mpCtx = (VtMpIntCtx)(obj->mpCtx);
    rsaGenCtx->modBits = keyGenInfo->modLenBits;
    rsaGenCtx->usageFlag = keyGenInfo->usageFlag;
    rsaGenCtx->prime1Bits = rsaGenCtx->modBits / 2;
    rsaGenCtx->prime2Bits = rsaGenCtx->prime1Bits;
    rsaGenCtx->prime1.data = buffer + sizeof (VoltRsaKeyGenCtx);
    rsaGenCtx->prime2.data = rsaGenCtx->prime1.data + prime1Len;
    rsaGenCtx->expo1.data = rsaGenCtx->prime2.data + prime2Len;
    rsaGenCtx->expo2.data = rsaGenCtx->expo1.data + prime1Len;
    rsaGenCtx->coeff.data = rsaGenCtx->expo2.data + prime2Len;
    rsaGenCtx->modulus.data = rsaGenCtx->coeff.data + prime1Len;
    rsaGenCtx->priExpo.data = rsaGenCtx->modulus.data + modLen;
    rsaGenCtx->pubExpo.data = rsaGenCtx->priExpo.data + modLen;

    rsaGenCtx->prime1.len = prime1Len;
    rsaGenCtx->prime2.len = prime2Len;
    rsaGenCtx->expo1.len = prime1Len;
    rsaGenCtx->expo2.len = prime2Len;
    rsaGenCtx->coeff.len = prime1Len;
    rsaGenCtx->modulus.len = modLen;
    rsaGenCtx->priExpo.len = modLen;

    Z2Memcpy (
      rsaGenCtx->pubExpo.data, keyGenInfo->pubExpo.data,
      keyGenInfo->pubExpo.len);
    rsaGenCtx->pubExpo.len = keyGenInfo->pubExpo.len;

    obj->keyType = VOLT_KEY_ALG_RSA | VOLT_KEY_TYPE_GEN_PAIR;
    obj->GenerateKey = RSAGenerateKeyPair;
    obj->localGenerateCtx = (Pointer)rsaGenCtx;
    obj->LocalGenerateCtxDestroy = VoltSimpleCtxDestroy;

    status = 0;

  } while (0);

  /* If everything worked, return 0.
   */
  if (status == 0)
    return (0);

  /* If something went wrong, destroy anything we created and indicate
   * that this object is not usable.
   */
  if (buffer != (unsigned char *)0)
    Z2Free (buffer);

  obj->keyType = 0;

  VOLT_LOG_ERROR_INFO (
    0, obj, status, 0, VT_ERROR_TYPE_PRIMARY,
    (char *)0, "SetObjectRSAKeyGen", fnctLine, (char *)0)

  return (status);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美精选一区二区| 欧美激情一区二区三区四区| 久久综合久久综合九色| 亚洲图片你懂的| 国产精品18久久久久久久久| 精品视频一区二区三区免费| 国产日韩欧美a| 免费人成网站在线观看欧美高清| bt7086福利一区国产| 日韩色视频在线观看| 亚洲欧美日本在线| 国产成人在线观看| 精品国产伦理网| 天堂影院一区二区| 91久久精品网| 中文字幕日本乱码精品影院| 精品一区二区三区在线观看国产 | 美女看a上一区| 欧美色中文字幕| 亚洲第一主播视频| 国产91精品免费| 日韩欧美一二三| 日韩经典中文字幕一区| 91在线丨porny丨国产| 国产视频亚洲色图| 久久电影国产免费久久电影| 欧美久久久一区| 亚洲一区在线观看免费| 色欧美片视频在线观看| 国产精品久久久久久久蜜臀 | 欧美高清dvd| 亚洲综合区在线| 色中色一区二区| 一区二区三区在线高清| 在线观看日韩精品| 亚洲成人tv网| 色综合久久久久久久久| 中文字幕色av一区二区三区| 成人午夜激情影院| 国产精品久久久久aaaa| 色综合久久中文字幕| 亚洲男女一区二区三区| 欧洲一区二区三区在线| 亚洲综合色婷婷| 欧美日韩国产美| 蜜桃av噜噜一区二区三区小说| 67194成人在线观看| 蜜桃精品视频在线| 久久久精品蜜桃| 91小视频免费观看| 亚洲高清不卡在线观看| 欧美刺激午夜性久久久久久久| 国产在线国偷精品免费看| 久久九九影视网| 一本色道久久综合亚洲aⅴ蜜桃 | 久久久久久免费网| 成人99免费视频| 亚洲第一成人在线| 欧美va亚洲va香蕉在线 | 免费观看一级特黄欧美大片| 26uuu精品一区二区在线观看| 国产精品一级在线| 亚洲精品一二三| 日韩欧美在线影院| 成人激情电影免费在线观看| 亚洲精品美国一| 日韩午夜激情av| 99国产精品国产精品毛片| 亚洲综合视频在线| 国产日韩视频一区二区三区| 色就色 综合激情| 美女视频黄 久久| 亚洲色图视频免费播放| 欧美成人精品福利| 91麻豆swag| 精品午夜一区二区三区在线观看| 自拍偷自拍亚洲精品播放| 日韩区在线观看| 一道本成人在线| 国产91在线观看| 日韩av成人高清| 亚洲免费成人av| 欧美激情一区二区三区四区| 欧美一区二区三区视频在线 | 亚洲欧美激情小说另类| 日韩美一区二区三区| 日本久久电影网| 国产精品一线二线三线精华| 亚洲午夜在线电影| 亚洲男女一区二区三区| 国产农村妇女毛片精品久久麻豆 | 成人午夜在线免费| 日本大胆欧美人术艺术动态| ...中文天堂在线一区| 日韩免费福利电影在线观看| 欧美日韩在线观看一区二区 | 亚洲一二三级电影| 国产精品久久久99| 久久久久国产精品麻豆ai换脸| 欧美高清激情brazzers| 在线免费精品视频| 欧美综合久久久| 在线观看av一区二区| 成人精品一区二区三区四区| 国产成人综合在线播放| 国产一区二区在线免费观看| 麻豆成人久久精品二区三区红 | 777精品伊人久久久久大香线蕉| caoporn国产精品| 成人久久视频在线观看| 国产精品996| 国产精品中文字幕欧美| 久久99精品久久久久久久久久久久| 亚洲图片你懂的| 欧美电影在线免费观看| 在线不卡a资源高清| 在线免费av一区| 色妹子一区二区| 波多野结衣亚洲一区| 国产一区二区伦理片| 久久99精品视频| 国产在线麻豆精品观看| 日本在线不卡一区| 轻轻草成人在线| 国产美女精品在线| 国产一区激情在线| 国产一区二区三区黄视频| 国产精品综合在线视频| 午夜视频在线观看一区二区三区| 日日嗨av一区二区三区四区| 亚洲成av人片| 玉足女爽爽91| 亚洲一区二区在线视频| 国产精品久久久久精k8| 亚洲愉拍自拍另类高清精品| 亚洲色图第一区| 亚洲男人电影天堂| 玉足女爽爽91| 亚洲美女区一区| 五月婷婷久久综合| 热久久一区二区| 国产真实乱子伦精品视频| 国产盗摄精品一区二区三区在线 | 精品免费视频一区二区| 精品美女一区二区| 色8久久精品久久久久久蜜| 欧美一级爆毛片| 久久久久97国产精华液好用吗| 国产日产欧产精品推荐色| 国产精品久久久一区麻豆最新章节| 欧美精品电影在线播放| 日本一区二区免费在线| 亚洲欧洲日韩综合一区二区| 一区二区三区在线视频播放| 亚洲18影院在线观看| 亚洲一本大道在线| 国产成人精品一区二区三区网站观看| 国产精品1区2区| 欧洲人成人精品| 欧美大片在线观看一区| 国产精品午夜在线| 亚洲大尺度视频在线观看| 国内精品不卡在线| 一本色道久久综合亚洲精品按摩| 欧美日韩国产三级| 久久久精品免费网站| 亚洲最大色网站| 成人激情文学综合网| 欧美日韩国产小视频在线观看| 久久精品亚洲精品国产欧美kt∨| 亚洲视频在线观看三级| 一区二区免费在线播放| 国产成人午夜精品影院观看视频 | 9色porny自拍视频一区二区| 欧美午夜免费电影| 国产精品久久久久久久久免费樱桃 | 精品一区二区三区日韩| 日本道在线观看一区二区| 欧美成人a∨高清免费观看| 最好看的中文字幕久久| 看电视剧不卡顿的网站| av福利精品导航| 亚洲国产精品成人综合 | 国产日韩欧美精品电影三级在线 | 亚洲午夜激情av| 国产乱码精品一品二品| 欧美一区二区啪啪| 一区二区三区四区乱视频| 国内外精品视频| 欧美日韩色综合| ...av二区三区久久精品| 国产91丝袜在线播放| 日韩一级二级三级| 亚洲第一在线综合网站| 日本精品裸体写真集在线观看 | 韩国女主播一区| 99riav一区二区三区| 中文字幕一区二区三区色视频| 韩国av一区二区三区| 日韩一二三区不卡|