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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? crypto.c

?? 開發(fā)源代碼的CPU卡的COS源程序。
?? C
字號(hào):
/* ============================================================================   Project Name : jayaCard   Module Name  : proto/bios/crypto/crypto.c   Version : $Id: crypto.c,v 1.31 2004/01/11 09:56:30 dgil Exp $	Description: Crypto BIOS    The Original Code is jayaCard code.    The Initial Developer of the Original Code is Gilles Dumortier.	Portions created by the Initial Developer are Copyright (C) 2002-2004 the    Initial Developer. All Rights Reserved.    Contributor(s):    This program is free software; you can redistribute it and/or modify    it under the terms of the GNU General Public License as published by    the Free Software Foundation; either version 2 of the License, or    (at your option) any later version.    This program is distributed in the hope that it will be useful,    but WITHOUT ANY WARRANTY; without even the implied warranty of    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the    GNU General Public License for more details.    You should have received a copy of the GNU General Public License    along with this program; see http://www.gnu.org/licenses/gpl.html   History Rev	Description   020903 dgil	wrote it from scratch   ============================================================================*/#include "precomp.h"/* =========================================================================	__bios_cipher_init()	algo:		init the IV if required		reset the hardware		prepare information if needed	secure: use global semaphore   ========================================================================= */void __bios_cipher_init(void){	LOG2("CRYPTO","BIOS_CIPHER_INIT: refdata_algo=0x%.2X refdata_pad=0x%.2X",refdata_algo,refdata_pad);    if (BIOS_CALL_OPCODE(OPCODE_INIT_CIPHER)!=JSEC_OK) {        #ifdef JAYACFG_IV_ZERO        if ((refdata_algo&CIPHER_ALGO_CBC_MODE)==CIPHER_ALGO_CBC_MODE) {            HAL_ERASE_XRAM(&u.bBlock[0],sizeof(CRYPTO_BUFFER));            LOG8("CRYPTO","BIOS_CIPHER_INIT: CBC / IV= %.2X%.2X%.2X%.2X%.2X%.2X%.2X%.2X",                u.bBlock[JAYA_BCRYPTO_INPUT0+0],                u.bBlock[JAYA_BCRYPTO_INPUT0+1],                u.bBlock[JAYA_BCRYPTO_INPUT0+2],                u.bBlock[JAYA_BCRYPTO_INPUT0+3],                u.bBlock[JAYA_BCRYPTO_INPUT0+4],                u.bBlock[JAYA_BCRYPTO_INPUT0+5],                u.bBlock[JAYA_BCRYPTO_INPUT0+6],                u.bBlock[JAYA_BCRYPTO_INPUT0+7]                );        }        #else        gGlobalSem++;        if ((refdata_algo&CIPHER_ALGO_CBC_MODE)==CIPHER_ALGO_CBC_MODE) {            LOCAL(jbyte,i);            /* init IV with random */            for (i=0; i<(sizeof(CRYPTO_BUFFER)/sizeof(jdword));) {                gGlobalSem--;                BIOS_RANDOM();                u.dwBlock[i++] = u.dwBlock[0];                u.dwBlock[i++] = u.dwBlock[1];                gGlobalSem--;            }            gGlobalSem++;            LOG8("CRYPTO","BIOS_CIPHER_INIT: CBC / IV= %.2X%.2X%.2X%.2X%.2X%.2X%.2X%.2X",                u.bBlock[JAYA_BCRYPTO_INPUT0+0],                u.bBlock[JAYA_BCRYPTO_INPUT0+1],                u.bBlock[JAYA_BCRYPTO_INPUT0+2],                u.bBlock[JAYA_BCRYPTO_INPUT0+3],                u.bBlock[JAYA_BCRYPTO_INPUT0+4],                u.bBlock[JAYA_BCRYPTO_INPUT0+5],                u.bBlock[JAYA_BCRYPTO_INPUT0+6],                u.bBlock[JAYA_BCRYPTO_INPUT0+7]                );        } else {            /* devnote: don't touch INPUT in EBC mode, please */            gGlobalSem++;        }        #endif        /* more initialization required by specific algorithm ? */        switch (refdata_algo&(~CIPHER_ALGO_CBC_MODE)) {            #ifdef JAYA_DES            case CIPHER_ALGO_ECB_DES: {                HAL_HARDWARE(HARDWARE_DES);            } break;            #endif            #ifdef JAYA_3DES            case CIPHER_ALGO_ECB_3DES2: {                LOCAL(jbyte,i);                /* keyC <- keyA */                for (i=0;i<8;i++) {                    r.bBlock[JAYA_BCRYPTO_KEYC+i] = r.bBlock[JAYA_BCRYPTO_KEYA+i];                }                HAL_HARDWARE(HARDWARE_DES);            } break;            case CIPHER_ALGO_ECB_3DES3: {                HAL_HARDWARE(HARDWARE_DES);            } break;            #endif            #ifdef JAYA_AES            case CIPHER_ALGO_ECB_AES: {                HAL_HARDWARE(HARDWARE_AES);            } break;            #endif            #ifdef JAYA_DESX            case CIPHER_ALGO_ECB_DESX: {                /* compute pre/post whitening keys */                /* IMPLEMENTME */            } break;            #endif            default:                break;        }    }	#ifdef PARANO_JITTER	/* __x add some jitter with the co-processor working */	#endif}/* =========================================================================	__bios_cipher_block()	Cipher operation just on a block   ========================================================================= */void __bios_cipher_block(jbool mode){	switch (refdata_algo&(~CIPHER_ALGO_CBC_MODE)) {		#ifdef JAYA_DES		case CIPHER_ALGO_ECB_DES:			HAL_DES(mode);			break;		#endif		#ifdef JAYA_DESX		case CIPHER_ALGO_ECB_DESX:			HAL_DESX(mode);			break;		#endif		#ifdef JAYA_3DES		case CIPHER_ALGO_ECB_3DES2:		case CIPHER_ALGO_ECB_3DES3:			HAL_3DES(mode);			break;		#endif		#ifdef JAYA_AES 		case CIPHER_ALGO_ECB_AES:			HAL_AES(mode);			break;		#endif		default:			LOG2("CRYPTO","Hummm. Unknown cipher %d algorithm %d !",mode,refdata_algo);			BIOS_SETERR(ERR_INVALID_ALGO);			HAL_HALT();			break;	}}/* =========================================================================	__bios_pad()	Note: this version supports only CHUNK sized to 8 bytes   ========================================================================= */void __bios_pad(jbyte xdata* buf,jbyte len){	LOCAL(jbyte,i);	switch (refdata_pad) {		case REFDATA_PAD_SPACE:		{			LOG1("CRYPTO","__bios_pad() - pad with space len=%d",len);			for (i=len ; i<8 ; i++) buf[i] = 0x20;		} break;		case REFDATA_PAD_ZERONUM:		{			LOG1("CRYPTO","__bios_pad() - pad with 000..00N len=%d",len);			for (i=len ; i<7 ; i++) buf[i] = 0x00;			buf[7] = 8-len;		} break;		case REFDATA_PAD_PKCS5:		{			LOG1("CRYPTO","__bios_pad() - pad with pkcs5 NNN...NN len=%d",len);			for (i=len ; i<8 ; i++) buf[i] = 8-len;		} break;		case REFDATA_PAD_EMV:		{			LOG1("CRYPTO","__bios_pad() - pad with emv 8000..00 len=%d",len);			buf[len]=0x80;			for (i=len+1 ; i<8 ; i++) buf[i] = 0x00;		} break;		default:			LOG1("CRYPTO","__bios_pad() - unknown padding method %d",refdata_pad);			/* fall-through */		case REFDATA_PAD_ZERO:		{			LOG1("CRYPTO","__bios_pad() - pad with 000...000 len=%d",len);			for (i=len ; i<8 ; i++) buf[i] = 0x00;		} break;	}	LOG8("CRYPTO","padded buffer = %.2X %.2X %.2X %.2X %.2X %.2X %.2X %.2X",			buf[0],buf[1],buf[2],buf[3],buf[4],buf[5],buf[6],buf[7]			);}/* =========================================================================	__bios_cipher()	Note: this version supports only CHUNK sized to 8 bytes   ========================================================================= */jbyte __bios_cipher(jbyte xdata* buf,jbyte len,jbool mode){	LOCAL(jbyte,i);	LOCAL(jbool,bExit);	LOCAL(jbyte,rlen);    /* codop for cipher ? */    if (BIOS_CALL_OPCODE(OPCODE_CIPHER)==JSEC_OK) return len;	bExit = jfalse;	rlen = len;	while (len>=8) {loop:		/* need to XOR the previous output ? */		if ((refdata_algo&CIPHER_ALGO_CBC_MODE)==CIPHER_ALGO_CBC_MODE) {			for (i=0;i<8;i++) {				u.bBlock[JAYA_BCRYPTO_INPUT0+i] = buf[i] ^ u.bBlock[JAYA_BCRYPTO_OUTPUT0+i];			}		} else {			for (i=0;i<8;i++) {				u.bBlock[JAYA_BCRYPTO_INPUT0+i] = buf[i];			}		}		/* call block cipher function */		BIOS_CIPHER_BLOCK(mode);		/* update the output buffer */		for (i=0;i<8;i++) {			buf[i] = u.bBlock[JAYA_BCRYPTO_OUTPUT0+i];		}		/* was the last block */		if (bExit) return rlen;		/* next chunk */		buf = buf + 8;		len = len - 8;	}	/* padding the latest chunk to encipher */    if ((mode==ENCIPHER) && ((refdata_pad != REFDATA_PAD_NOPAD) || (len>0)) ) {		/* one more block ? */		rlen = ((rlen/8)+1)*8;		/* call block pad function */        BIOS_PAD(buf,len);		/* one more block to encipher */		bExit = jtrue;		goto loop;	}	return rlen;}/* =========================================================================	__bios_crypto_cleanup()	secure: use global semaphore   ========================================================================= */void __bios_crypto_cleanup(void){	LOG("CRYPTO","BIOS_CRYPTO_CLEANUP");	/* cleanup the key area and temporary buffers */	HAL_ERASE_XRAM(&u.bBlock[0],sizeof(CRYPTO_BUFFER));	gGlobalSem--;	HAL_ERASE_IRAM(&r.bBlock[0],sizeof(CRYPTO_REGISTERS));	gGlobalSem--;	#ifdef PARANO_JITTER	/* __x add some jitter with the co-processor working */	#endif	/* stop the crypto components */	HAL_HARDWARE(HARDWARE_NONE);	/* gGlobalSem should be == JSEC_SEM-1 */}/* =========================================================================	That's all folks !   ========================================================================= */

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩一区在线播放| 色综合天天综合网天天看片| 欧美精品一区二区三区视频| 日本美女一区二区| 欧美—级在线免费片| 国产91在线观看| 国产精品国产自产拍高清av| 91最新地址在线播放| 亚洲综合区在线| 欧美一区二区国产| 国产一区二区三区在线观看免费视频| 精品美女在线观看| youjizz国产精品| 亚洲一区在线视频观看| 91精品国产综合久久婷婷香蕉| 美腿丝袜亚洲一区| 国产精品无圣光一区二区| 一本到三区不卡视频| 性欧美大战久久久久久久久| 欧美不卡一区二区三区| 成人午夜大片免费观看| 一区二区三区久久| 欧美电影免费观看高清完整版| 国产成人免费视频| 一区二区三区丝袜| 久久综合色综合88| 91成人网在线| 国产电影一区在线| 亚洲制服丝袜av| 久久午夜色播影院免费高清 | 亚洲一区自拍偷拍| 日韩一区二区在线观看视频播放| 国产精品一区二区三区乱码| 亚洲激情自拍偷拍| 26uuu欧美| 欧美午夜精品一区二区三区| 国产麻豆精品久久一二三| 亚洲精品精品亚洲| 久久青草欧美一区二区三区| 欧美在线观看视频在线| 国产美女在线观看一区| 亚洲成av人片在线观看| 国产精品伦一区二区三级视频| 欧美日韩电影一区| 波多野结衣一区二区三区| 青青青爽久久午夜综合久久午夜| 国产精品久久久久久久久图文区| 91精品一区二区三区久久久久久| 99国产精品99久久久久久| 美女精品一区二区| 一区二区成人在线视频| 国产精品乱码一区二区三区软件| 欧美一二三区精品| 欧美吞精做爰啪啪高潮| 成人av在线网站| 国产一区二区三区高清播放| 日本不卡一二三区黄网| 一区二区三区国产| 亚洲日本免费电影| 欧美高清一级片在线观看| 精品国产污网站| 这里是久久伊人| 在线视频国内自拍亚洲视频| av不卡免费电影| 国产成人精品亚洲午夜麻豆| 激情丁香综合五月| 久久国产福利国产秒拍| 日韩精品91亚洲二区在线观看 | 国内成人免费视频| 蜜臀a∨国产成人精品| 亚洲动漫第一页| 一区二区三区久久| 一区二区在线观看视频在线观看| 国产精品久久久久婷婷二区次| 2欧美一区二区三区在线观看视频| 91精品一区二区三区久久久久久| 欧美日韩国产一级| 欧美久久一二三四区| 欧美日韩国产综合草草| 欧美日韩成人在线| 欧美美女bb生活片| 欧美美女网站色| 4438x亚洲最大成人网| 91精品国产综合久久香蕉的特点| 欧美精品自拍偷拍动漫精品| 欧美高清视频不卡网| 制服丝袜中文字幕一区| 日韩一级在线观看| 精品国产一区二区精华| 国产欧美视频在线观看| 亚洲已满18点击进入久久| 亚洲成人资源在线| 日韩av高清在线观看| 激情图片小说一区| 国产精品影音先锋| aaa国产一区| 欧洲日韩一区二区三区| 欧美浪妇xxxx高跟鞋交| 日韩欧美亚洲另类制服综合在线| 精品国产一区二区三区不卡| 中文子幕无线码一区tr| 亚洲黄色av一区| 日本一道高清亚洲日美韩| 国产综合久久久久影院| aaa欧美色吧激情视频| 欧美日韩国产免费一区二区 | 色综合久久天天综合网| 欧美日韩国产免费一区二区| 欧美精品一区二区久久婷婷| 中文字幕成人网| 亚洲电影激情视频网站| 九九在线精品视频| 91麻豆国产香蕉久久精品| 91麻豆精品国产91久久久资源速度 | 久久国产尿小便嘘嘘尿| 成人黄色大片在线观看| 欧美少妇bbb| 国产片一区二区三区| 亚洲综合免费观看高清完整版| 老司机一区二区| 99re这里都是精品| 日韩欧美电影一二三| 日韩伦理电影网| 精品中文字幕一区二区| 一本一道久久a久久精品| 日韩精品一区二区三区在线| 亚洲欧美日韩电影| 精品在线一区二区三区| 日本精品一级二级| 久久网站热最新地址| 亚洲第一成人在线| 成人中文字幕合集| 欧美一区二区精品在线| 最近日韩中文字幕| 国内久久精品视频| 欧美美女直播网站| 国产精品免费看片| 狠狠色综合播放一区二区| 欧美性猛片aaaaaaa做受| 中国av一区二区三区| 蜜臀av一区二区| 欧美三级在线看| 蜜桃视频一区二区三区| 色哟哟一区二区| 国产蜜臀av在线一区二区三区| 日本 国产 欧美色综合| 在线观看一区不卡| 亚洲欧美日韩人成在线播放| 国产高清精品在线| 久久一区二区三区国产精品| 蜜臀久久久99精品久久久久久| 欧美午夜片在线观看| 亚洲乱码国产乱码精品精98午夜 | 国产成人午夜精品影院观看视频| 91精品久久久久久久99蜜桃| 亚洲影院免费观看| 色婷婷综合在线| 中文字幕佐山爱一区二区免费| 国产一区二区三区综合| 日韩欧美一级在线播放| 日韩精品久久久久久| 欧美高清dvd| 午夜精品视频一区| 欧洲av一区二区嗯嗯嗯啊| 亚洲欧美激情一区二区| caoporm超碰国产精品| 国产精品嫩草99a| www.久久精品| 国产精品久久午夜| www.亚洲激情.com| 日韩理论片网站| 色av一区二区| 亚洲香肠在线观看| 欧美巨大另类极品videosbest | 久久精工是国产品牌吗| 日韩欧美一二三| 国产综合一区二区| 中文字幕欧美区| 成人美女视频在线观看| 综合精品久久久| 在线免费观看不卡av| 无吗不卡中文字幕| 日韩一级完整毛片| 国产激情视频一区二区三区欧美| 国产欧美一区二区三区鸳鸯浴| 波多野结衣在线aⅴ中文字幕不卡| 亚洲人精品午夜| 7777精品伊人久久久大香线蕉| 日本网站在线观看一区二区三区| 欧美tickle裸体挠脚心vk| 国产在线精品一区二区不卡了| 亚洲国产精品成人综合色在线婷婷| 99国产精品久久久久久久久久| 亚洲午夜视频在线| 日韩色视频在线观看| 粉嫩aⅴ一区二区三区四区五区| 亚洲日本va在线观看| 欧美一级久久久久久久大片| 国产激情视频一区二区在线观看 | 亚洲欧洲色图综合|