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

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

?? rabinmiller.c

?? IBE是一種非對稱密碼技術
?? C
?? 第 1 頁 / 共 2 頁
字號:

    /* The Rabin-Miller test starts out by representing the prime
     * candidate as
     *    candidate = 1 + (mVal * 2^expo)
     * This is what's going on.
     *    Find candidate - 1, this is an even number (candidate is odd)
     *    How many trailing 0's are there in the binary representation
     *      of candidate - 1. That's expo.
     *    Shift candidate right expo bits, that's now mVal.
     */
    VOLT_SET_ERROR_TYPE (errorType, 0)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->CreateMpInt ((Pointer)mpCtx, &mVal);
    if (status != 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->MpIntToMpInt (primeCandidate, mVal);
    if (status != 0)
      break;

    /* Find primeCandidate - 1. We'll use it for comparison purposes
     * later.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->CreateMpInt ((Pointer)mpCtx, &candidateMinusOne);
    if (status != 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->MpIntToMpInt (primeCandidate, candidateMinusOne);
    if (status != 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->SetBit (candidateMinusOne, 0, 0);
    if (status != 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->CreateMpInt ((Pointer)mpCtx, &randVal);
    if (status != 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->CreateMpInt ((Pointer)mpCtx, &zVal);
    if (status != 0)
      break;

    /* Find the number of trailing 0's. After subtracting 1, the 0'th
     * bit is 0, so start looking at bit position 1. Use index as a
     * temp variable.
     */
    for (expo = 1; expo < primeSizeBits; ++expo)
    {
      VOLT_SET_FNCT_LINE (fnctLine)
      status = mpCtx->GetBit (mVal, expo, &index);
      if (status != 0)
        break;
      if (index == 1)
        break;
    }

    VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
    VOLT_SET_FNCT_LINE (fnctLine)
    if (expo >= primeSizeBits)
      status = VT_ERROR_MP_INT_RANGE;
    if (status != 0)
      break;

    /* Step 2, find expo and mVal, we have expo, but the MpInt mVal is
     * currently equal to candidate - 1. Shift it right expo bits and
     * we have mVal.
     */
    VOLT_SET_ERROR_TYPE (errorType, 0)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->ShiftRightBits (mVal, expo);
    if (status != 0)
      break;

    /* Perform the Rabin-Miller algorithm the prescribed number of
     * times.
     */
    for (index = 0; index < iterationCount; ++index)
    {
      /* Step 3, get a random number < candidate.
       */
      VOLT_SET_FNCT_LINE (fnctLine)
      status = GetRandomValue (
        libCtx, mpCtx, primeCandidate, buffer, bufferSize);
      if (status != 0)
        break;

      VOLT_SET_FNCT_LINE (fnctLine)
      buffer[0] &= 0x7f;
      status = mpCtx->OctetStringToMpInt (0, buffer, bufferSize, randVal);
      if (status != 0)
        break;

      /* Step 4, find zVal = (randVal ^ mVal) mod candidate
       */
      VOLT_SET_FNCT_LINE (fnctLine)
      status = mpCtx->ModExp (randVal, mVal, primeCandidate, zVal);
      if (status != 0)
        break;

      /* Step 5, if zVal == 1 or zVal == candidate - 1, the test passes
       * this iteration.
       */
      VOLT_SET_FNCT_LINE (fnctLine)
      status = mpCtx->MpIntToInt (zVal, 1, &value);
      if (status != VT_ERROR_MP_INT_RANGE)
      {
        if (status != 0)
          break;

        if (value == 1)
          continue;
      }
      else
      {
        VOLT_SET_FNCT_LINE (fnctLine)
        status = mpCtx->Compare (zVal, candidateMinusOne, &compareResult);
        if (status != 0)
          break;

        if (compareResult == 0)
          continue;
      }

      /* Step 6, square zVal, make a comparison (step 5), then loop.
       */
      for (count = 1; count < expo; ++count)
      {
        VOLT_SET_FNCT_LINE (fnctLine)
        status = mpCtx->Square (zVal, randVal);
        if (status != 0)
          break;

        VOLT_SET_FNCT_LINE (fnctLine)
        status = mpCtx->ModReduce (randVal, primeCandidate, zVal);
        if (status != 0)
          break;

        /* Step 5 comparison, if zVal now == candidate - 1, this
         * iteration passes, move on to the next random number.
         */
        VOLT_SET_FNCT_LINE (fnctLine)
        status = mpCtx->Compare (zVal, candidateMinusOne, &compareResult);
        if (status != 0)
          break;

        if (compareResult == 0)
          break;

        /* If zVal is now 1, we know the candidate is not prime.
         */
        VOLT_SET_FNCT_LINE (fnctLine)
        status = mpCtx->MpIntToInt (zVal, 1,&value);
        if (status != VT_ERROR_MP_INT_RANGE)
        {
          if (status != 0)
            break;

          /* Set expo to count to skip the rest of the zVal^2 tests, we
           * know the number is not prime.
           */
          if (value == 1)
            count = expo;
        }
        status = 0;
      }
      if (status != 0)
        break;

      /* If we broke out of the step 6 loop early, the comparison was
       * equal, we can move on to the next iteration.
       * If we looped step 6 every time and found no match, this number
       * is not prime. Exit the Rabin-Miller iterations.
       */
      if (count >= expo)
        break;
    }
    if (status != 0)
      break;

    /* If we didn't break out of the loop early, we did every
     * iteration, which means the number passes.
     */
    if (index >= iterationCount)
      *isPrime = 1;

  } while (0);

  /* We cleared the low order bit for comparison purposes, set it back.
   */
  mpCtx->SetBit (primeCandidate, 0, 1);

  if (buffer != (unsigned char *)0)
    Z2Free (buffer);

  mpCtx->DestroyMpInt (&candidateMinusOne);
  mpCtx->DestroyMpInt (&mVal);
  mpCtx->DestroyMpInt (&zVal);
  mpCtx->DestroyMpInt (&randVal);

  VOLT_LOG_ERROR_COMPARE (
    status, (VtLibCtx)libCtx, status, errorType, fnctLine,
    "VoltRabinMillerTest", (char *)0)

  return (status);
}

int VoltCheckRelativePrime (
   VoltMpIntCtx *mpCtx,
   VoltMpInt *relativePrime,
   VoltMpInt *prime,
   VoltMpInt *temp1,
   VoltMpInt *temp2,
   unsigned int *relPrime
   )
{
  int status;
  unsigned int bitLen;
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  /* Initialize to true, if they turn out not to be relatively prime,
   * we'll reset it.
   */
  *relPrime = 1;

  do
  {
    /* Find prime / relativePrime. If the remainder is 1, then p - 1
     * would not be relatively prime.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->Divide (prime, relativePrime, temp1, temp2);
    if (status != 0)
      break;

    /* If the bitLen of the remainder is not 1, the remainder cannot be
     * 1, so the values are relatively prime.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->GetBitLength (temp2, &bitLen);
    if (status != 0)
      break;

    if (bitLen != 1)
      break;

    /* The bit length is 1, but there is a very slight chance that the
     * remainder is 0. That would mean prime (actually a prime
     * candidate) is a multiple of relativePrime. Even though the
     * chance is slim, we have to program for the possibility.
     * Use bitLen as a temp variable.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->GetBit (temp2, 0, &bitLen);
    if (status != 0)
      break;

    /* If the bit is 0, the remainder is 0, so p - 1 and relativePrime
     * are indeed relatively prime.
     */
    if (bitLen != 0)
      *relPrime = 0;

  } while (0);

  VOLT_LOG_ERROR_INFO_COMPARE (
    status, 0, mpCtx, status, 0, 0,
    (char *)0, "VoltCheckRelativePrime", fnctLine, (char *)0)

  return (status);
}

static int GetRandomValue (
   VoltLibCtx *libCtx,
   VoltMpIntCtx *mpCtx,
   VoltMpInt *primeCandidate,
   unsigned char *buffer,
   unsigned int bufferLen
   )
{
  int status;
  unsigned int sign, pLen, bytesNeeded, copyCount, offset, digestLen;
  VtAlgorithmObject digester = (VtAlgorithmObject)0;
  unsigned char *pBuf = (unsigned char *)0;
  unsigned char digest[20];
  VOLT_DECLARE_ERROR_TYPE (errorType)
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  do
  {
    /* Get the primeCandidate into a buffer.
     */
    VOLT_SET_ERROR_TYPE (errorType, 0)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->MpIntToOctetString (
      primeCandidate, &sign, (unsigned char *)0, 0, &pLen);
    if (status == 0)
      status = VT_ERROR_GENERAL;
    if (status != VT_ERROR_BUFFER_TOO_SMALL)
      break;

    VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_MEMORY;
    pBuf = (unsigned char *)Z2Malloc (pLen, VOLT_MEMORY_SENSITIVE);
    if (pBuf == (unsigned char *)0)
      break;

    VOLT_SET_ERROR_TYPE (errorType, 0)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = mpCtx->MpIntToOctetString (
      primeCandidate, &sign, pBuf, pLen, &pLen);
    if (status != 0)
      break;

    status = VtCreateAlgorithmObject (
      (VtLibCtx)libCtx, VtAlgorithmImplSHA1, (Pointer)0, &digester);
    if (status != 0)
      break;

    /* As long as there are bytes needed, digest.
     */
    bytesNeeded = bufferLen;
    offset = 0;
    do
    {
      copyCount = bytesNeeded;
      if (bytesNeeded >= 20)
        copyCount = 20;
      bytesNeeded -= copyCount;

      status = VtDigestInit (digester);
      if (status != 0)
        break;

      status = VtDigestUpdate (digester, pBuf, pLen);
      if (status != 0)
        break;

      status = VtDigestFinal (
        digester, buffer, bufferLen, digest, sizeof (digest), &digestLen);
      if (status != 0)
        break;

      Z2Memcpy (buffer + offset, digest, copyCount);
      offset += copyCount;

    } while (bytesNeeded != 0);

  } while (0);

  Z2Memset (digest, 0, sizeof (digest));

  if (pBuf != (unsigned char *)0)
    Z2Free (pBuf);

  VtDestroyAlgorithmObject (&digester);

  VOLT_LOG_ERROR_COMPARE (
    status, (VtLibCtx)libCtx, status, errorType, fnctLine,
    "GetRandomValue", (char *)0)

  return (status);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线成人小视频| 亚洲大型综合色站| 亚洲gay无套男同| 国产精品1区2区3区| 欧美日韩卡一卡二| 成人免费在线视频| 美女高潮久久久| 欧美色综合久久| 国产精品久久久久久妇女6080| 免费av网站大全久久| 91女人视频在线观看| 久久精品夜夜夜夜久久| 日本美女一区二区三区| 欧美三级电影在线看| 国产精品久久久久一区二区三区| 久久99久久久久久久久久久| 欧美日韩视频在线观看一区二区三区| 中文字幕av在线一区二区三区| 美腿丝袜在线亚洲一区| 欧美日韩成人高清| 亚洲精品日韩一| voyeur盗摄精品| 国产精品午夜在线观看| 国模少妇一区二区三区| 久久综合九色综合97婷婷女人 | 美洲天堂一区二卡三卡四卡视频| 色域天天综合网| 中文字幕亚洲综合久久菠萝蜜| 国产九色精品成人porny| 久久亚洲捆绑美女| 国产成人午夜高潮毛片| 国产精品视频麻豆| 99在线精品一区二区三区| 亚洲视频在线观看三级| 色悠悠亚洲一区二区| 亚洲蜜臀av乱码久久精品蜜桃| 久久影视一区二区| 国产精品88av| 国产精品色婷婷久久58| 99久久精品免费看国产免费软件| 亚洲欧美在线高清| 91在线观看下载| 亚洲综合免费观看高清完整版在线 | 久久蜜桃av一区精品变态类天堂| 久久成人免费电影| 欧美激情一区二区在线| 91在线精品一区二区| 亚洲最新视频在线观看| 欧美日本不卡视频| 美女www一区二区| 国产三级精品在线| 色综合视频在线观看| 午夜精品在线看| 精品国精品国产尤物美女| 国产不卡一区视频| 亚洲精品午夜久久久| 欧美一区二区三区视频在线观看| 久久超碰97人人做人人爱| 国产精品视频yy9299一区| 色婷婷亚洲精品| 麻豆91在线看| 中文字幕在线不卡一区| 欧美日韩在线播| 国模一区二区三区白浆| 亚洲免费看黄网站| 精品日韩一区二区三区免费视频| 成人视屏免费看| 日韩电影在线免费看| 国产精品乱子久久久久| 欧美精品1区2区| 99国产欧美久久久精品| 奇米精品一区二区三区在线观看一| 国产亚洲一二三区| 欧美日本一区二区在线观看| 国产一区二区三区在线观看免费视频 | 亚洲欧美日韩中文播放| 日韩限制级电影在线观看| 成人高清视频免费观看| 麻豆精品一区二区| 亚洲一二三四在线观看| 久久精品亚洲国产奇米99| 欧美性色综合网| youjizz久久| 韩国女主播一区| 天天色天天爱天天射综合| 最新不卡av在线| 国产偷v国产偷v亚洲高清| 欧美日韩久久一区| 色婷婷综合五月| 成人av网址在线| 国产精品18久久久久| 日本免费新一区视频| 一区二区视频免费在线观看| 国产欧美一区二区精品性| 日韩午夜激情av| 欧美日韩国产小视频在线观看| av午夜一区麻豆| 成人av在线网| 成人免费视频caoporn| 久久99国产乱子伦精品免费| 日韩精品一二三| 99精品欧美一区二区三区综合在线| 久国产精品韩国三级视频| 亚洲一二三四区| 亚洲综合自拍偷拍| 亚洲另类在线制服丝袜| 亚洲视频网在线直播| 国产精品久久久一本精品 | 亚洲高清视频在线| 亚洲图片欧美综合| 亚洲成人黄色影院| 五月天中文字幕一区二区| 亚洲成人午夜影院| 日韩电影在线免费| 麻豆精品一二三| 国产精品一区二区在线看| 国产乱人伦偷精品视频免下载| 经典三级视频一区| 国产精品一级片| 国产不卡视频在线播放| 高清视频一区二区| 97aⅴ精品视频一二三区| 91在线云播放| 欧美日韩精品免费观看视频| 欧美日韩精品一区二区三区| 91精品国产高清一区二区三区蜜臀 | 色偷偷久久一区二区三区| 91久久精品国产91性色tv| 欧美日韩美少妇| 欧美tk—视频vk| 中文文精品字幕一区二区| 国产精品视频你懂的| 亚洲精品菠萝久久久久久久| 亚洲综合丁香婷婷六月香| 丝袜亚洲另类丝袜在线| 久久99久久久久| 99精品欧美一区二区三区小说| 一本久道久久综合中文字幕| 欧美乱妇15p| 国产亚洲成aⅴ人片在线观看| 国产精品毛片高清在线完整版 | 欧美午夜宅男影院| 正在播放亚洲一区| 国产欧美一区二区精品性| 一区二区三区不卡视频| 日韩av电影免费观看高清完整版 | 欧美一区2区视频在线观看| 国产欧美一区二区三区鸳鸯浴 | 国产在线精品一区二区不卡了| 国产精品1024| 欧美日韩你懂得| 久久久久久久久久看片| 亚洲免费三区一区二区| 另类中文字幕网| 91国内精品野花午夜精品| 午夜精品久久久久久久99水蜜桃 | 国产精品久久毛片| 日本91福利区| 色婷婷综合久久久久中文一区二区| 欧美电影免费观看高清完整版在线观看 | 国产高清不卡一区二区| 欧美日韩精品三区| 国产日韩欧美麻豆| 日韩精品午夜视频| 日本韩国一区二区三区| 久久免费美女视频| 日韩成人午夜电影| 97se亚洲国产综合自在线不卡 | 亚洲欧美色一区| 国产麻豆精品在线| 欧美一区二区三区白人| 亚洲图片另类小说| 丰满少妇久久久久久久| 91精品福利在线一区二区三区 | 亚洲美女偷拍久久| 国产成人在线影院| 日韩欧美国产小视频| 亚洲国产精品天堂| 日本精品裸体写真集在线观看| 国产日韩精品一区二区浪潮av| 日韩和欧美一区二区三区| 色香蕉成人二区免费| 国产欧美一区二区三区鸳鸯浴 | 欧美日韩成人高清| 一区二区三区国产豹纹内裤在线| 国产不卡视频一区二区三区| 精品国精品国产尤物美女| 蜜桃视频免费观看一区| 欧美日韩国产欧美日美国产精品| 国产精品成人在线观看| 成人在线视频一区二区| 久久久噜噜噜久久中文字幕色伊伊 | 精品国产乱码久久久久久1区2区| 午夜激情一区二区| 欧美日韩国产123区| 亚洲成av人影院| 8x福利精品第一导航| 五月天一区二区三区| 欧美一二三区在线| 麻豆精品视频在线|