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

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

?? aes_ige.c

?? OpenSSL 0.9.8k 最新版OpenSSL
?? C
字號:
/* crypto/aes/aes_ige.c -*- mode:C; c-file-style: "eay" -*- *//* ==================================================================== * Copyright (c) 2006 The OpenSSL Project.  All rights reserved. * * 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 above 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 acknowledgment: *    "This product includes software developed by the OpenSSL Project *    for use in the OpenSSL Toolkit. (http://www.openssl.org/)" * * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to *    endorse or promote products derived from this software without *    prior written permission. For written permission, please contact *    openssl-core@openssl.org. * * 5. Products derived from this software may not be called "OpenSSL" *    nor may "OpenSSL" appear in their names without prior written *    permission of the OpenSSL Project. * * 6. Redistributions of any form whatsoever must retain the following *    acknowledgment: *    "This product includes software developed by the OpenSSL Project *    for use in the OpenSSL Toolkit (http://www.openssl.org/)" * * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY * EXPRESSED 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 OpenSSL PROJECT OR * ITS 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. * ==================================================================== * */#include "cryptlib.h"#include <openssl/aes.h>#include "aes_locl.h"#define N_WORDS (AES_BLOCK_SIZE / sizeof(unsigned long))typedef struct {        unsigned long data[N_WORDS];} aes_block_t;/* XXX: probably some better way to do this */#if defined(__i386__) || defined(__x86_64__)#define UNALIGNED_MEMOPS_ARE_FAST 1#else#define UNALIGNED_MEMOPS_ARE_FAST 0#endif#if UNALIGNED_MEMOPS_ARE_FAST#define load_block(d, s)        (d) = *(const aes_block_t *)(s)#define store_block(d, s)       *(aes_block_t *)(d) = (s)#else#define load_block(d, s)        memcpy((d).data, (s), AES_BLOCK_SIZE)#define store_block(d, s)       memcpy((d), (s).data, AES_BLOCK_SIZE)#endif/* N.B. The IV for this mode is _twice_ the block size */void AES_ige_encrypt(const unsigned char *in, unsigned char *out,					 const unsigned long length, const AES_KEY *key,					 unsigned char *ivec, const int enc)	{	unsigned long n;	unsigned long len;	OPENSSL_assert(in && out && key && ivec);	OPENSSL_assert((AES_ENCRYPT == enc)||(AES_DECRYPT == enc));	OPENSSL_assert((length%AES_BLOCK_SIZE) == 0);	len = length / AES_BLOCK_SIZE;	if (AES_ENCRYPT == enc)		{		if (in != out &&		    (UNALIGNED_MEMOPS_ARE_FAST || ((size_t)in|(size_t)out|(size_t)ivec)%sizeof(long)==0))			{			aes_block_t *ivp = (aes_block_t *)ivec;			aes_block_t *iv2p = (aes_block_t *)(ivec + AES_BLOCK_SIZE);			while (len)				{				aes_block_t *inp = (aes_block_t *)in;				aes_block_t *outp = (aes_block_t *)out;				for(n=0 ; n < N_WORDS; ++n)					outp->data[n] = inp->data[n] ^ ivp->data[n];				AES_encrypt((unsigned char *)outp->data, (unsigned char *)outp->data, key);				for(n=0 ; n < N_WORDS; ++n)					outp->data[n] ^= iv2p->data[n];				ivp = outp;				iv2p = inp;				--len;				in += AES_BLOCK_SIZE;				out += AES_BLOCK_SIZE;				}			memcpy(ivec, ivp->data, AES_BLOCK_SIZE);			memcpy(ivec + AES_BLOCK_SIZE, iv2p->data, AES_BLOCK_SIZE);			}		else			{			aes_block_t tmp, tmp2;			aes_block_t iv;			aes_block_t iv2;			load_block(iv, ivec);			load_block(iv2, ivec + AES_BLOCK_SIZE);			while (len)				{				load_block(tmp, in);				for(n=0 ; n < N_WORDS; ++n)					tmp2.data[n] = tmp.data[n] ^ iv.data[n];				AES_encrypt((unsigned char *)tmp2.data, (unsigned char *)tmp2.data, key);				for(n=0 ; n < N_WORDS; ++n)					tmp2.data[n] ^= iv2.data[n];				store_block(out, tmp2);				iv = tmp2;				iv2 = tmp;				--len;				in += AES_BLOCK_SIZE;				out += AES_BLOCK_SIZE;				}			memcpy(ivec, iv.data, AES_BLOCK_SIZE);			memcpy(ivec + AES_BLOCK_SIZE, iv2.data, AES_BLOCK_SIZE);			}		}	else		{		if (in != out &&		    (UNALIGNED_MEMOPS_ARE_FAST || ((size_t)in|(size_t)out|(size_t)ivec)%sizeof(long)==0))			{			aes_block_t *ivp = (aes_block_t *)ivec;			aes_block_t *iv2p = (aes_block_t *)(ivec + AES_BLOCK_SIZE);			while (len)				{				aes_block_t tmp;				aes_block_t *inp = (aes_block_t *)in;				aes_block_t *outp = (aes_block_t *)out;				for(n=0 ; n < N_WORDS; ++n)					tmp.data[n] = inp->data[n] ^ iv2p->data[n];				AES_decrypt((unsigned char *)tmp.data, (unsigned char *)outp->data, key);				for(n=0 ; n < N_WORDS; ++n)					outp->data[n] ^= ivp->data[n];				ivp = inp;				iv2p = outp;				--len;				in += AES_BLOCK_SIZE;				out += AES_BLOCK_SIZE;				}			memcpy(ivec, ivp->data, AES_BLOCK_SIZE);			memcpy(ivec + AES_BLOCK_SIZE, iv2p->data, AES_BLOCK_SIZE);			}		else			{			aes_block_t tmp, tmp2;			aes_block_t iv;			aes_block_t iv2;			load_block(iv, ivec);			load_block(iv2, ivec + AES_BLOCK_SIZE);			while (len)				{				load_block(tmp, in);				tmp2 = tmp;				for(n=0 ; n < N_WORDS; ++n)					tmp.data[n] ^= iv2.data[n];				AES_decrypt((unsigned char *)tmp.data, (unsigned char *)tmp.data, key);				for(n=0 ; n < N_WORDS; ++n)					tmp.data[n] ^= iv.data[n];				store_block(out, tmp);				iv = tmp2;				iv2 = tmp;				--len;				in += AES_BLOCK_SIZE;				out += AES_BLOCK_SIZE;				}			memcpy(ivec, iv.data, AES_BLOCK_SIZE);			memcpy(ivec + AES_BLOCK_SIZE, iv2.data, AES_BLOCK_SIZE);			}		}	}/* * Note that its effectively impossible to do biIGE in anything other * than a single pass, so no provision is made for chaining. *//* N.B. The IV for this mode is _four times_ the block size */void AES_bi_ige_encrypt(const unsigned char *in, unsigned char *out,						const unsigned long length, const AES_KEY *key,						const AES_KEY *key2, const unsigned char *ivec,						const int enc)	{	unsigned long n;	unsigned long len = length;	unsigned char tmp[AES_BLOCK_SIZE];	unsigned char tmp2[AES_BLOCK_SIZE];	unsigned char tmp3[AES_BLOCK_SIZE];	unsigned char prev[AES_BLOCK_SIZE];	const unsigned char *iv;	const unsigned char *iv2;	OPENSSL_assert(in && out && key && ivec);	OPENSSL_assert((AES_ENCRYPT == enc)||(AES_DECRYPT == enc));	OPENSSL_assert((length%AES_BLOCK_SIZE) == 0);	if (AES_ENCRYPT == enc)		{		/* XXX: Do a separate case for when in != out (strictly should		   check for overlap, too) */		/* First the forward pass */ 		iv = ivec;		iv2 = ivec + AES_BLOCK_SIZE;		while (len >= AES_BLOCK_SIZE)			{			for(n=0 ; n < AES_BLOCK_SIZE ; ++n)				out[n] = in[n] ^ iv[n];			AES_encrypt(out, out, key);			for(n=0 ; n < AES_BLOCK_SIZE ; ++n)				out[n] ^= iv2[n];			iv = out;			memcpy(prev, in, AES_BLOCK_SIZE);			iv2 = prev;			len -= AES_BLOCK_SIZE;			in += AES_BLOCK_SIZE;			out += AES_BLOCK_SIZE;			}		/* And now backwards */		iv = ivec + AES_BLOCK_SIZE*2;		iv2 = ivec + AES_BLOCK_SIZE*3;		len = length;		while(len >= AES_BLOCK_SIZE)			{			out -= AES_BLOCK_SIZE;			/* XXX: reduce copies by alternating between buffers */			memcpy(tmp, out, AES_BLOCK_SIZE);			for(n=0 ; n < AES_BLOCK_SIZE ; ++n)				out[n] ^= iv[n];			/*			hexdump(stdout, "out ^ iv", out, AES_BLOCK_SIZE); */			AES_encrypt(out, out, key);			/*			hexdump(stdout,"enc", out, AES_BLOCK_SIZE); */			/*			hexdump(stdout,"iv2", iv2, AES_BLOCK_SIZE); */			for(n=0 ; n < AES_BLOCK_SIZE ; ++n)				out[n] ^= iv2[n];			/*			hexdump(stdout,"out", out, AES_BLOCK_SIZE); */			iv = out;			memcpy(prev, tmp, AES_BLOCK_SIZE);			iv2 = prev;			len -= AES_BLOCK_SIZE;			}		}	else		{		/* First backwards */		iv = ivec + AES_BLOCK_SIZE*2;		iv2 = ivec + AES_BLOCK_SIZE*3;		in += length;		out += length;		while (len >= AES_BLOCK_SIZE)			{			in -= AES_BLOCK_SIZE;			out -= AES_BLOCK_SIZE;			memcpy(tmp, in, AES_BLOCK_SIZE);			memcpy(tmp2, in, AES_BLOCK_SIZE);			for(n=0 ; n < AES_BLOCK_SIZE ; ++n)				tmp[n] ^= iv2[n];			AES_decrypt(tmp, out, key);			for(n=0 ; n < AES_BLOCK_SIZE ; ++n)				out[n] ^= iv[n];			memcpy(tmp3, tmp2, AES_BLOCK_SIZE);			iv = tmp3;			iv2 = out;			len -= AES_BLOCK_SIZE;			}		/* And now forwards */		iv = ivec;		iv2 = ivec + AES_BLOCK_SIZE;		len = length;		while (len >= AES_BLOCK_SIZE)			{			memcpy(tmp, out, AES_BLOCK_SIZE);			memcpy(tmp2, out, AES_BLOCK_SIZE);			for(n=0 ; n < AES_BLOCK_SIZE ; ++n)				tmp[n] ^= iv2[n];			AES_decrypt(tmp, out, key);			for(n=0 ; n < AES_BLOCK_SIZE ; ++n)				out[n] ^= iv[n];			memcpy(tmp3, tmp2, AES_BLOCK_SIZE);			iv = tmp3;			iv2 = out;			len -= AES_BLOCK_SIZE;			in += AES_BLOCK_SIZE;			out += AES_BLOCK_SIZE;			}		}	}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲成人午夜电影| 欧美三级韩国三级日本三斤| 91香蕉视频在线| 91精品国产高清一区二区三区蜜臀 | 欧美一区二区网站| 亚洲欧美影音先锋| 国产一区欧美日韩| 欧美一区二区福利在线| 一区二区三区在线观看视频| 国产呦精品一区二区三区网站| 在线免费观看日本一区| 中文在线一区二区| 全国精品久久少妇| 3751色影院一区二区三区| 亚洲人成精品久久久久久| 国产精品亚洲人在线观看| 制服丝袜成人动漫| 夜夜精品视频一区二区 | 琪琪一区二区三区| 欧美性色黄大片| 亚洲精品国产高清久久伦理二区| 激情欧美日韩一区二区| 欧美日本不卡视频| 亚洲伊人色欲综合网| 色综合久久久久综合体桃花网| 亚洲精品欧美二区三区中文字幕| 成人av网站大全| 中文字幕精品在线不卡| 国产99久久久精品| 国产清纯在线一区二区www| 国产又粗又猛又爽又黄91精品| 日韩一级黄色片| 日韩国产精品久久久久久亚洲| 欧美日韩国产在线观看| 亚洲高清视频的网址| 欧美日韩亚洲高清一区二区| 五月天一区二区| 欧美男生操女生| 日韩黄色免费网站| 日韩视频一区在线观看| 狠狠色丁香久久婷婷综合丁香| 欧美精品日韩一区| 男女男精品视频网| 久久九九国产精品| aa级大片欧美| 亚洲成人av在线电影| 欧美精品aⅴ在线视频| 日韩激情一二三区| 久久久久久久久97黄色工厂| 国产白丝网站精品污在线入口| 中文在线一区二区| 色综合天天视频在线观看| 亚洲香蕉伊在人在线观| 欧美区一区二区三区| 日本欧美肥老太交大片| 久久久久亚洲综合| 99视频精品全部免费在线| 一区二区三区影院| 日韩精品一区二区三区视频在线观看| 久久精品国产第一区二区三区| 久久久久综合网| 91九色02白丝porn| 强制捆绑调教一区二区| 国产女同互慰高潮91漫画| 色综合久久综合网97色综合| 视频在线观看国产精品| 26uuu精品一区二区| 99久久婷婷国产精品综合| 婷婷激情综合网| 欧美国产激情二区三区| 欧美三级乱人伦电影| 国产成人一级电影| 亚洲国产综合91精品麻豆| 精品盗摄一区二区三区| 91麻豆精品视频| 九九国产精品视频| 一区二区三区在线观看视频| 久久夜色精品一区| 91高清视频免费看| 国产盗摄一区二区三区| 午夜精品久久久久久久99樱桃| 久久午夜电影网| 欧美精品高清视频| 91美女在线观看| 国产美女在线观看一区| 天天操天天色综合| 最好看的中文字幕久久| 久久先锋资源网| 欧美精品日日鲁夜夜添| 91麻豆产精品久久久久久| 国内精品国产成人| 三级欧美在线一区| 一区二区三区成人| 国产精品青草综合久久久久99| 91精品国产黑色紧身裤美女| 色综合一个色综合| 成人免费看黄yyy456| 国内成+人亚洲+欧美+综合在线| 亚洲bt欧美bt精品777| 国产精品国产三级国产aⅴ中文| 欧美成人性战久久| 91精品国产入口在线| 欧美日韩日日夜夜| 欧美在线观看一区二区| 91丨九色丨蝌蚪丨老版| 成人精品gif动图一区| 国产精品1区二区.| 国产精品影视天天线| 国产在线国偷精品产拍免费yy| 日韩成人一级片| 丝袜美腿亚洲综合| 日韩av中文在线观看| 丝袜美腿亚洲色图| 亚洲bt欧美bt精品777| 亚洲成人av一区| 天天av天天翘天天综合网色鬼国产 | 蜜臀av一区二区在线免费观看| 午夜精品久久久久久久| 日韩中文字幕区一区有砖一区| 亚洲成a人v欧美综合天堂下载| 亚洲午夜在线视频| 视频一区二区中文字幕| 日本视频一区二区三区| 精品一区二区三区视频在线观看| 精品亚洲成a人在线观看| 国产一区二区在线电影| 国产黄色精品网站| av不卡在线观看| 在线免费观看日本欧美| 欧美日本一道本| 日韩三级中文字幕| 久久九九99视频| 国产精品久久国产精麻豆99网站| 国产精品美女久久久久aⅴ| 亚洲色图欧美在线| 亚洲成人av一区二区| 久久精品国产久精国产| 国产成人av在线影院| 91在线视频18| 欧美精品99久久久**| 久久久久久久免费视频了| 亚洲天堂福利av| 亚洲aⅴ怡春院| 国产suv精品一区二区三区| 99精品欧美一区| 欧美老肥妇做.爰bbww视频| 精品国产凹凸成av人导航| 国产精品久久夜| 视频一区二区三区在线| 成人午夜视频网站| 欧美日韩视频专区在线播放| 久久久久久久久伊人| 亚洲国产日韩精品| 国产成人精品免费| 精品视频资源站| 国产精品网曝门| 日韩高清一区二区| 99视频一区二区三区| 日韩精品一区二区在线| 亚洲欧美激情小说另类| 久久99国内精品| 色菇凉天天综合网| 精品播放一区二区| 亚洲午夜精品在线| 9i在线看片成人免费| 日韩精品一区二| 亚洲国产成人高清精品| 国产999精品久久| 日韩免费性生活视频播放| 一区二区三区在线影院| 国产99久久久国产精品潘金网站| 91精品国产一区二区三区蜜臀| 成人免费在线观看入口| 国产精品综合在线视频| 91精品欧美一区二区三区综合在| 亚洲日本在线天堂| 懂色一区二区三区免费观看| 日韩精品中文字幕一区二区三区| 伊人性伊人情综合网| jvid福利写真一区二区三区| 欧美xxxx老人做受| 蜜芽一区二区三区| 欧美三级午夜理伦三级中视频| 亚洲三级电影全部在线观看高清| 国产精品一区二区果冻传媒| 这里只有精品99re| 午夜激情久久久| 欧美无砖专区一中文字| 亚洲精品免费在线| 北条麻妃一区二区三区| 久久网站热最新地址| 激情图片小说一区| 精品黑人一区二区三区久久 | 国产在线视频精品一区| 欧美大肚乱孕交hd孕妇| 秋霞午夜鲁丝一区二区老狼| 91精品国产综合久久精品性色| 性做久久久久久免费观看| 欧美精品v国产精品v日韩精品| 丝袜亚洲另类欧美综合|