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

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

?? bn_recp.c

?? LINUX AU12XX BOOTLADER
?? C
字號:
/* crypto/bn/bn_recp.c *//* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) * All rights reserved. * * This package is an SSL implementation written * by Eric Young (eay@cryptsoft.com). * The implementation was written so as to conform with Netscapes SSL. *  * This library is free for commercial and non-commercial use as long as * the following conditions are aheared to.  The following conditions * apply to all code found in this distribution, be it the RC4, RSA, * lhash, DES, etc., code; not just the SSL code.  The SSL documentation * included with this distribution is covered by the same copyright terms * except that the holder is Tim Hudson (tjh@cryptsoft.com). *  * Copyright remains Eric Young's, and as such any Copyright notices in * the code are not to be removed. * If this package is used in a product, Eric Young should be given attribution * as the author of the parts of the library used. * This can be in the form of a textual message at program startup or * in documentation (online or textual) provided with the package. *  * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the copyright *    notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in the *    documentation and/or other materials provided with the distribution. * 3. All advertising materials mentioning features or use of this software *    must display the following acknowledgement: *    "This product includes cryptographic software written by *     Eric Young (eay@cryptsoft.com)" *    The word 'cryptographic' can be left out if the rouines from the library *    being used are not cryptographic related :-). * 4. If you include any Windows specific code (or a derivative thereof) from  *    the apps directory (application code) you must include an acknowledgement: *    "This product includes software written by Tim Hudson (tjh@cryptsoft.com)" *  * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. *  * The licence and distribution terms for any publically available version or * derivative of this code cannot be changed.  i.e. this code cannot simply be * copied and put under another distribution licence * [including the GNU Public Licence.] */#include <stdio.h>#include "cryptlib.h"#include "bn_lcl.h"#include "workaround.h"void BN_RECP_CTX_init(BN_RECP_CTX * recp){    BN_init(&(recp->N));    BN_init(&(recp->Nr));    recp->num_bits = 0;    recp->flags = 0;}BN_RECP_CTX *BN_RECP_CTX_new(void){    BN_RECP_CTX *ret;    if ((ret = (BN_RECP_CTX *) Our_malloc(sizeof(BN_RECP_CTX))) == NULL)	return (NULL);    BN_RECP_CTX_init(ret);    ret->flags = BN_FLG_MALLOCED;    return (ret);}void BN_RECP_CTX_free(BN_RECP_CTX * recp){    if (recp == NULL)	return;    BN_free(&(recp->N));    BN_free(&(recp->Nr));    if (recp->flags & BN_FLG_MALLOCED)	OPENSSL_free(recp);}int BN_RECP_CTX_set(BN_RECP_CTX * recp, const BIGNUM * d, BN_CTX * ctx){    BN_copy(&(recp->N), d);    BN_zero(&(recp->Nr));    recp->num_bits = BN_num_bits(d);    recp->shift = 0;    return (1);}int BN_mod_mul_reciprocal(BIGNUM * r, BIGNUM * x, BIGNUM * y,			  BN_RECP_CTX * recp, BN_CTX * ctx){    int ret = 0;    BIGNUM *a;    BN_CTX_start(ctx);    if ((a = BN_CTX_get(ctx)) == NULL)	goto err;    if (y != NULL) {	if (x == y) {	    if (!BN_sqr(a, x, ctx))		goto err;	} else {	    if (!BN_mul(a, x, y, ctx))		goto err;	}    } else	a = x;			/* Just do the mod */    BN_div_recp(NULL, r, a, recp, ctx);    ret = 1;  err:    BN_CTX_end(ctx);    return (ret);}int BN_div_recp(BIGNUM * dv, BIGNUM * rem, BIGNUM * m, BN_RECP_CTX * recp,		BN_CTX * ctx){    int i, j, ret = 0;    BIGNUM *a, *b, *d, *r;    BN_CTX_start(ctx);    a = BN_CTX_get(ctx);    b = BN_CTX_get(ctx);    if (dv != NULL)	d = dv;    else	d = BN_CTX_get(ctx);    if (rem != NULL)	r = rem;    else	r = BN_CTX_get(ctx);    if (a == NULL || b == NULL || d == NULL || r == NULL)	goto err;    if (BN_ucmp(m, &(recp->N)) < 0) {	BN_zero(d);	BN_copy(r, m);	BN_CTX_end(ctx);	return (1);    }    /* We want the remainder     * Given input of ABCDEF / ab     * we need multiply ABCDEF by 3 digests of the reciprocal of ab     *     */    i = BN_num_bits(m);    j = recp->num_bits << 1;    if (j > i)	i = j;    j >>= 1;    if (i != recp->shift)	recp->shift = BN_reciprocal(&(recp->Nr), &(recp->N), i, ctx);    if (!BN_rshift(a, m, j))	goto err;    if (!BN_mul(b, a, &(recp->Nr), ctx))	goto err;    if (!BN_rshift(d, b, i - j))	goto err;    d->neg = 0;    if (!BN_mul(b, &(recp->N), d, ctx))	goto err;    if (!BN_usub(r, m, b))	goto err;    r->neg = 0;#if 1    j = 0;    while (BN_ucmp(r, &(recp->N)) >= 0) {	if (j++ > 2) {	    BNerr(BN_F_BN_MOD_MUL_RECIPROCAL, BN_R_BAD_RECIPROCAL);	    goto err;	}	if (!BN_usub(r, r, &(recp->N)))	    goto err;	if (!BN_add_word(d, 1))	    goto err;    }#endif    r->neg = BN_is_zero(r) ? 0 : m->neg;    d->neg = m->neg ^ recp->N.neg;    ret = 1;  err:    BN_CTX_end(ctx);    return (ret);}/* len is the expected size of the result * We actually calculate with an extra word of precision, so * we can do faster division if the remainder is not required. */int BN_reciprocal(BIGNUM * r, BIGNUM * m, int len, BN_CTX * ctx){    int ret = -1;    BIGNUM t;    BN_init(&t);    BN_zero(&t);    if (!BN_set_bit(&t, len))	goto err;    if (!BN_div(r, NULL, &t, m, ctx))	goto err;    ret = len;  err:    BN_free(&t);    return (ret);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91丨国产丨九色丨pron| 欧美久久久影院| 制服丝袜一区二区三区| 国产亚洲一区字幕| 日本午夜精品视频在线观看 | 色综合天天综合狠狠| 国产精品九色蝌蚪自拍| 亚洲成人综合在线| 成人网页在线观看| 日韩精品一区二区三区在线| 一区二区三区在线观看网站| 成人中文字幕合集| 日韩欧美不卡一区| 免费成人在线观看视频| 欧美日韩免费一区二区三区视频| 国产午夜精品久久久久久免费视| 免费人成在线不卡| 欧美久久久久久久久久| 亚洲一区二区av电影| 91免费视频网址| 亚洲女同ⅹxx女同tv| 成人免费电影视频| 中文字幕欧美激情一区| 国产盗摄精品一区二区三区在线| 日韩一区二区三区电影在线观看| 午夜精品福利一区二区三区av| 在线看国产一区二区| 一区二区三区四区视频精品免费 | 视频一区视频二区在线观看| 91九色最新地址| 一区二区三区在线播放| 色妞www精品视频| 亚洲一区二区在线观看视频| 在线免费精品视频| 日韩1区2区3区| 日韩欧美综合一区| 国产一区二区三区久久久| 26uuu精品一区二区三区四区在线| 久久精品国产精品亚洲综合| 久久影院午夜片一区| 国产激情精品久久久第一区二区 | 97se亚洲国产综合在线| 日韩一区在线播放| 欧美亚洲图片小说| 人人超碰91尤物精品国产| 精品对白一区国产伦| 国产白丝网站精品污在线入口| 久久久久高清精品| 9色porny自拍视频一区二区| 一区二区在线电影| 欧美一区二区三区四区视频| 国产一区二区三区四区在线观看| 国产亚洲成aⅴ人片在线观看 | 亚洲一区二区视频在线观看| 欧美日韩高清影院| 国产一区高清在线| 亚洲品质自拍视频| 日韩一区二区三区视频在线观看| 国产精品一二三四五| 中文字幕一区二区三区四区不卡| 91视频com| 久久国产精品色婷婷| 国产精品超碰97尤物18| 91行情网站电视在线观看高清版| 首页国产丝袜综合| 中文字幕中文字幕一区| 91精品国产一区二区三区| 懂色av一区二区三区免费看| 亚洲观看高清完整版在线观看| 日韩一卡二卡三卡| 91猫先生在线| 精品制服美女久久| 国产精品久久免费看| 欧美丰满美乳xxx高潮www| 国产成人一级电影| 蜜桃av噜噜一区| 亚洲精品美国一| 国产亚洲人成网站| 91精品国产综合久久久蜜臀粉嫩| 盗摄精品av一区二区三区| 日韩1区2区日韩1区2区| 一区二区在线观看不卡| 26uuu精品一区二区| 欧美精品久久久久久久多人混战| 粉嫩嫩av羞羞动漫久久久| 日本特黄久久久高潮| 亚洲狠狠丁香婷婷综合久久久| 久久精品在线免费观看| 欧美一级精品大片| 精品视频在线看| 色综合久久六月婷婷中文字幕| 国产一区中文字幕| 精品一区二区在线播放| 日韩精品三区四区| 亚洲国产精品一区二区www在线| 中文字幕久久午夜不卡| 欧美tk—视频vk| 91精品免费在线观看| 欧美午夜精品一区二区蜜桃| www.欧美日韩国产在线| 国产精品1024久久| 国产成人精品一区二| 精品在线亚洲视频| 精品伊人久久久久7777人| 五月天视频一区| 亚洲不卡一区二区三区| 亚洲成人在线观看视频| 亚洲一区二区五区| 亚洲国产精品久久人人爱| 亚洲一区在线观看免费观看电影高清| 国产精品久久久久影院| 日本一二三四高清不卡| 国产午夜精品一区二区三区嫩草| 精品国产伦一区二区三区观看体验 | 日日骚欧美日韩| 亚洲mv在线观看| 日韩国产高清影视| 日韩专区中文字幕一区二区| 日韩高清电影一区| 美女爽到高潮91| 国产在线日韩欧美| 国产精品99精品久久免费| 国产精品综合一区二区| 国产精品一区免费在线观看| 国产成人综合精品三级| 成人黄色免费短视频| 91在线免费播放| 欧美日韩中文一区| 日韩精品在线一区| 国产情人综合久久777777| 国产精品国产三级国产普通话三级| 国产精品久久久久天堂| 亚洲欧美国产高清| 日日夜夜精品视频免费 | 日韩黄色一级片| 麻豆精品视频在线观看免费| 国产麻豆一精品一av一免费| 91亚洲精品一区二区乱码| 欧美在线不卡一区| 欧美大片拔萝卜| 中文字幕一区二区三区四区 | 亚洲一级电影视频| 美国精品在线观看| 成人av网站免费| 7777精品伊人久久久大香线蕉经典版下载 | 国产精品视频九色porn| 亚洲一区在线观看免费观看电影高清| 日韩精品视频网站| 国产成人精品亚洲777人妖| 色婷婷一区二区三区四区| 日韩一级二级三级精品视频| 国产精品免费看片| 日韩精品亚洲专区| 成人av在线一区二区| 欧美一区二区女人| 国产精品卡一卡二卡三| 日韩av一区二| 暴力调教一区二区三区| 欧美一区二区网站| 亚洲欧洲在线观看av| 蜜臀久久久99精品久久久久久| 成人av影视在线观看| 日韩欧美国产一区二区三区| 亚洲人成网站影音先锋播放| 久久99国内精品| 4438x亚洲最大成人网| 亚洲色图视频网| 国产精品一区二区在线观看不卡| 欧美三级电影精品| 亚洲欧美一区二区三区久本道91| 美洲天堂一区二卡三卡四卡视频| 99久久er热在这里只有精品15| 精品国产sm最大网站免费看| 亚洲第一福利视频在线| 成人激情文学综合网| www一区二区| 精品一区二区三区免费播放| 欧美日韩色综合| 亚洲男人都懂的| 粉嫩av一区二区三区在线播放| 欧美一区二区三区思思人| 亚洲激情中文1区| 99精品黄色片免费大全| 国产日韩欧美综合在线| 九九视频精品免费| 欧美成人午夜电影| 免费在线观看日韩欧美| 3atv在线一区二区三区| 亚洲主播在线播放| 色婷婷综合久久久久中文| 亚洲精品自拍动漫在线| 91丨porny丨国产入口| 中文字幕国产一区二区| 国产精品18久久久| 国产女同互慰高潮91漫画| 韩国三级电影一区二区| 久久综合色播五月| 国模一区二区三区白浆| 久久综合九色综合久久久精品综合| 久久精品噜噜噜成人88aⅴ|