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

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

?? crypt_z990.h

?? h內核
?? H
字號:
/* * Cryptographic API. * * Support for z990 cryptographic instructions. * *   Copyright (C) 2003 IBM Deutschland GmbH, IBM Corporation *   Author(s): Thomas Spatzier (tspat@de.ibm.com) * * 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. * */#ifndef _CRYPTO_ARCH_S390_CRYPT_Z990_H#define _CRYPTO_ARCH_S390_CRYPT_Z990_H#include <asm/errno.h>#define CRYPT_Z990_OP_MASK 0xFF00#define CRYPT_Z990_FUNC_MASK 0x00FF/*z990 cryptographic operations*/enum crypt_z990_operations {	CRYPT_Z990_KM   = 0x0100,	CRYPT_Z990_KMC  = 0x0200,	CRYPT_Z990_KIMD = 0x0300,	CRYPT_Z990_KLMD = 0x0400,	CRYPT_Z990_KMAC = 0x0500};/*function codes for KM (CIPHER MESSAGE) instruction*/enum crypt_z990_km_func {	KM_QUERY            = CRYPT_Z990_KM | 0,	KM_DEA_ENCRYPT      = CRYPT_Z990_KM | 1,	KM_DEA_DECRYPT      = CRYPT_Z990_KM | 1 | 0x80, //modifier bit->decipher	KM_TDEA_128_ENCRYPT = CRYPT_Z990_KM | 2,	KM_TDEA_128_DECRYPT = CRYPT_Z990_KM | 2 | 0x80,	KM_TDEA_192_ENCRYPT = CRYPT_Z990_KM | 3,	KM_TDEA_192_DECRYPT = CRYPT_Z990_KM | 3 | 0x80,};/*function codes for KMC (CIPHER MESSAGE WITH CHAINING) instruction*/enum crypt_z990_kmc_func {	KMC_QUERY            = CRYPT_Z990_KMC | 0,	KMC_DEA_ENCRYPT      = CRYPT_Z990_KMC | 1,	KMC_DEA_DECRYPT      = CRYPT_Z990_KMC | 1 | 0x80, //modifier bit->decipher	KMC_TDEA_128_ENCRYPT = CRYPT_Z990_KMC | 2,	KMC_TDEA_128_DECRYPT = CRYPT_Z990_KMC | 2 | 0x80,	KMC_TDEA_192_ENCRYPT = CRYPT_Z990_KMC | 3,	KMC_TDEA_192_DECRYPT = CRYPT_Z990_KMC | 3 | 0x80,};/*function codes for KIMD (COMPUTE INTERMEDIATE MESSAGE DIGEST) instruction*/enum crypt_z990_kimd_func {	KIMD_QUERY   = CRYPT_Z990_KIMD | 0,	KIMD_SHA_1   = CRYPT_Z990_KIMD | 1,};/*function codes for KLMD (COMPUTE LAST MESSAGE DIGEST) instruction*/enum crypt_z990_klmd_func {	KLMD_QUERY   = CRYPT_Z990_KLMD | 0,	KLMD_SHA_1   = CRYPT_Z990_KLMD | 1,};/*function codes for KMAC (COMPUTE MESSAGE AUTHENTICATION CODE) instruction*/enum crypt_z990_kmac_func {	KMAC_QUERY    = CRYPT_Z990_KMAC | 0,	KMAC_DEA      = CRYPT_Z990_KMAC | 1,	KMAC_TDEA_128 = CRYPT_Z990_KMAC | 2,	KMAC_TDEA_192 = CRYPT_Z990_KMAC | 3};/*status word for z990 crypto instructions' QUERY functions*/struct crypt_z990_query_status {	u64 high;	u64 low;};/* * Standard fixup and ex_table sections for crypt_z990 inline functions. * label 0: the z990 crypto operation * label 1: just after 1 to catch illegal operation exception on non-z990 * label 6: the return point after fixup * label 7: set error value if exception _in_ crypto operation * label 8: set error value if illegal operation exception * [ret] is the variable to receive the error code * [ERR] is the error code value */#ifndef __s390x__#define __crypt_z990_fixup \	".section .fixup,\"ax\" \n"	\	"7:	lhi	%0,%h[e1] \n"	\	"	bras	1,9f \n"	\	"	.long	6b \n"		\	"8:	lhi	%0,%h[e2] \n"	\	"	bras	1,9f \n"	\	"	.long	6b \n"		\	"9:	l	1,0(1) \n"	\	"	br	1 \n"		\	".previous \n"			\	".section __ex_table,\"a\" \n"	\	"	.align	4 \n"		\	"	.long	0b,7b \n"	\	"	.long	1b,8b \n"	\	".previous"#else /* __s390x__ */#define __crypt_z990_fixup \	".section .fixup,\"ax\" \n"	\	"7:	lhi	%0,%h[e1] \n"	\	"	jg	6b \n"		\	"8:	lhi	%0,%h[e2] \n"	\	"	jg	6b \n"		\	".previous\n"			\	".section __ex_table,\"a\" \n"	\	"	.align	8 \n"		\	"	.quad	0b,7b \n"	\	"	.quad	1b,8b \n"	\	".previous"#endif /* __s390x__ *//* * Standard code for setting the result of z990 crypto instructions. * %0: the register which will receive the result * [result]: the register containing the result (e.g. second operand length * to compute number of processed bytes]. */#ifndef __s390x__#define __crypt_z990_set_result \	"	lr	%0,%[result] \n"#else /* __s390x__ */#define __crypt_z990_set_result \	"	lgr	%0,%[result] \n"#endif/* * Executes the KM (CIPHER MESSAGE) operation of the z990 CPU. * @param func: the function code passed to KM; see crypt_z990_km_func * @param param: address of parameter block; see POP for details on each func * @param dest: address of destination memory area * @param src: address of source memory area * @param src_len: length of src operand in bytes * @returns < zero for failure, 0 for the query func, number of processed bytes * 	for encryption/decryption funcs */static inline intcrypt_z990_km(long func, void* param, u8* dest, const u8* src, long src_len){	register long __func asm("0") = func & CRYPT_Z990_FUNC_MASK;	register void* __param asm("1") = param;	register u8* __dest asm("4") = dest;	register const u8* __src asm("2") = src;	register long __src_len asm("3") = src_len;	int ret;	ret = 0;	__asm__ __volatile__ (		"0:	.insn	rre,0xB92E0000,%1,%2 \n" //KM opcode		"1:	brc	1,0b \n" //handle partial completion		__crypt_z990_set_result		"6:	\n"		__crypt_z990_fixup		: "+d" (ret), "+a" (__dest), "+a" (__src),		  [result] "+d" (__src_len)		: [e1] "K" (-EFAULT), [e2] "K" (-ENOSYS), "d" (__func),		  "a" (__param)		: "cc", "memory"	);	if (ret >= 0 && func & CRYPT_Z990_FUNC_MASK){		ret = src_len - ret;	}	return ret;}/* * Executes the KMC (CIPHER MESSAGE WITH CHAINING) operation of the z990 CPU. * @param func: the function code passed to KM; see crypt_z990_kmc_func * @param param: address of parameter block; see POP for details on each func * @param dest: address of destination memory area * @param src: address of source memory area * @param src_len: length of src operand in bytes * @returns < zero for failure, 0 for the query func, number of processed bytes * 	for encryption/decryption funcs */static inline intcrypt_z990_kmc(long func, void* param, u8* dest, const u8* src, long src_len){	register long __func asm("0") = func & CRYPT_Z990_FUNC_MASK;	register void* __param asm("1") = param;	register u8* __dest asm("4") = dest;	register const u8* __src asm("2") = src;	register long __src_len asm("3") = src_len;	int ret;	ret = 0;	__asm__ __volatile__ (		"0:	.insn	rre,0xB92F0000,%1,%2 \n" //KMC opcode		"1:	brc	1,0b \n" //handle partial completion		__crypt_z990_set_result		"6:	\n"		__crypt_z990_fixup		: "+d" (ret), "+a" (__dest), "+a" (__src),		  [result] "+d" (__src_len)		: [e1] "K" (-EFAULT), [e2] "K" (-ENOSYS), "d" (__func),		  "a" (__param)		: "cc", "memory"	);	if (ret >= 0 && func & CRYPT_Z990_FUNC_MASK){		ret = src_len - ret;	}	return ret;}/* * Executes the KIMD (COMPUTE INTERMEDIATE MESSAGE DIGEST) operation * of the z990 CPU. * @param func: the function code passed to KM; see crypt_z990_kimd_func * @param param: address of parameter block; see POP for details on each func * @param src: address of source memory area * @param src_len: length of src operand in bytes * @returns < zero for failure, 0 for the query func, number of processed bytes * 	for digest funcs */static inline intcrypt_z990_kimd(long func, void* param, const u8* src, long src_len){	register long __func asm("0") = func & CRYPT_Z990_FUNC_MASK;	register void* __param asm("1") = param;	register const u8* __src asm("2") = src;	register long __src_len asm("3") = src_len;	int ret;	ret = 0;	__asm__ __volatile__ (		"0:	.insn	rre,0xB93E0000,%1,%1 \n" //KIMD opcode		"1:	brc	1,0b \n" /*handle partical completion of kimd*/		__crypt_z990_set_result		"6:	\n"		__crypt_z990_fixup		: "+d" (ret), "+a" (__src), [result] "+d" (__src_len)		: [e1] "K" (-EFAULT), [e2] "K" (-ENOSYS), "d" (__func),		  "a" (__param)		: "cc", "memory"	);	if (ret >= 0 && (func & CRYPT_Z990_FUNC_MASK)){		ret = src_len - ret;	}	return ret;}/* * Executes the KLMD (COMPUTE LAST MESSAGE DIGEST) operation of the z990 CPU. * @param func: the function code passed to KM; see crypt_z990_klmd_func * @param param: address of parameter block; see POP for details on each func * @param src: address of source memory area * @param src_len: length of src operand in bytes * @returns < zero for failure, 0 for the query func, number of processed bytes * 	for digest funcs */static inline intcrypt_z990_klmd(long func, void* param, const u8* src, long src_len){	register long __func asm("0") = func & CRYPT_Z990_FUNC_MASK;	register void* __param asm("1") = param;	register const u8* __src asm("2") = src;	register long __src_len asm("3") = src_len;	int ret;	ret = 0;	__asm__ __volatile__ (		"0:	.insn	rre,0xB93F0000,%1,%1 \n" //KLMD opcode		"1:	brc	1,0b \n" /*handle partical completion of klmd*/		__crypt_z990_set_result		"6:	\n"		__crypt_z990_fixup		: "+d" (ret), "+a" (__src), [result] "+d" (__src_len)		: [e1] "K" (-EFAULT), [e2] "K" (-ENOSYS), "d" (__func),		  "a" (__param)		: "cc", "memory"	);	if (ret >= 0 && func & CRYPT_Z990_FUNC_MASK){		ret = src_len - ret;	}	return ret;}/* * Executes the KMAC (COMPUTE MESSAGE AUTHENTICATION CODE) operation * of the z990 CPU. * @param func: the function code passed to KM; see crypt_z990_klmd_func * @param param: address of parameter block; see POP for details on each func * @param src: address of source memory area * @param src_len: length of src operand in bytes * @returns < zero for failure, 0 for the query func, number of processed bytes * 	for digest funcs */static inline intcrypt_z990_kmac(long func, void* param, const u8* src, long src_len){	register long __func asm("0") = func & CRYPT_Z990_FUNC_MASK;	register void* __param asm("1") = param;	register const u8* __src asm("2") = src;	register long __src_len asm("3") = src_len;	int ret;	ret = 0;	__asm__ __volatile__ (		"0:	.insn	rre,0xB91E0000,%5,%5 \n" //KMAC opcode		"1:	brc	1,0b \n" /*handle partical completion of klmd*/		__crypt_z990_set_result		"6:	\n"		__crypt_z990_fixup		: "+d" (ret), "+a" (__src), [result] "+d" (__src_len)		: [e1] "K" (-EFAULT), [e2] "K" (-ENOSYS), "d" (__func),		  "a" (__param)		: "cc", "memory"	);	if (ret >= 0 && func & CRYPT_Z990_FUNC_MASK){		ret = src_len - ret;	}	return ret;}/** * Tests if a specific z990 crypto function is implemented on the machine. * @param func:	the function code of the specific function; 0 if op in general * @return	1 if func available; 0 if func or op in general not available */static inline intcrypt_z990_func_available(int func){	int ret;	struct crypt_z990_query_status status = {		.high = 0,		.low = 0	};	switch (func & CRYPT_Z990_OP_MASK){		case CRYPT_Z990_KM:			ret = crypt_z990_km(KM_QUERY, &status, NULL, NULL, 0);			break;		case CRYPT_Z990_KMC:			ret = crypt_z990_kmc(KMC_QUERY, &status, NULL, NULL, 0);			break;		case CRYPT_Z990_KIMD:			ret = crypt_z990_kimd(KIMD_QUERY, &status, NULL, 0);			break;		case CRYPT_Z990_KLMD:			ret = crypt_z990_klmd(KLMD_QUERY, &status, NULL, 0);			break;		case CRYPT_Z990_KMAC:			ret = crypt_z990_kmac(KMAC_QUERY, &status, NULL, 0);			break;		default:			ret = 0;			return ret;	}	if (ret >= 0){		func &= CRYPT_Z990_FUNC_MASK;		func &= 0x7f; //mask modifier bit		if (func < 64){			ret = (status.high >> (64 - func - 1)) & 0x1;		} else {			ret = (status.low >> (128 - func - 1)) & 0x1;		}	} else {		ret = 0;	}	return ret;}#endif // _CRYPTO_ARCH_S390_CRYPT_Z990_H

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久精品免费看国产免费软件| 久久久九九九九| 久久综合资源网| 综合久久国产九一剧情麻豆| 日韩黄色一级片| 99久久国产综合色|国产精品| 日韩免费观看高清完整版| 亚洲丝袜精品丝袜在线| 韩国av一区二区| 4438亚洲最大| 亚洲夂夂婷婷色拍ww47| 不卡一区二区在线| 久久亚洲精品国产精品紫薇| 日日夜夜一区二区| 一本大道久久a久久精品综合| 国产午夜精品一区二区三区嫩草| 午夜婷婷国产麻豆精品| 91香蕉视频黄| 欧美激情一区二区三区四区| 精久久久久久久久久久| 欧美久久久久免费| 亚洲一区二区高清| 91美女在线看| 日韩码欧中文字| 99久久亚洲一区二区三区青草| 久久精品亚洲一区二区三区浴池| 日本视频中文字幕一区二区三区| 欧美日韩在线精品一区二区三区激情| 亚洲视频香蕉人妖| a级精品国产片在线观看| 国产视频在线观看一区二区三区| 韩国av一区二区三区四区| 日韩欧美精品在线视频| 日韩高清一区二区| 欧美巨大另类极品videosbest | 久久久久高清精品| 久久超碰97中文字幕| 精品国产一区二区精华| 麻豆成人91精品二区三区| 欧美一区二区视频网站| 精品一区二区三区在线视频| 日韩欧美国产综合| 精品亚洲国内自在自线福利| www激情久久| 国产成人自拍高清视频在线免费播放| 精品国产乱码久久久久久老虎| 经典三级一区二区| 欧美高清一级片在线观看| 99这里只有精品| 一区二区视频在线| 在线观看91av| 国产综合久久久久久鬼色| 久久综合色综合88| 99综合电影在线视频| 亚洲第一激情av| 制服丝袜一区二区三区| 国产一区二区三区精品欧美日韩一区二区三区| 日韩精品一区二区三区三区免费| 国产精品69久久久久水密桃| 国产精品三级电影| 欧美丝袜自拍制服另类| 久久er99热精品一区二区| 中文字幕一区二区三区精华液 | 精品国产第一区二区三区观看体验| 久久69国产一区二区蜜臀| 中文久久乱码一区二区| 欧美日韩精品三区| 国产激情视频一区二区在线观看| 亚洲免费电影在线| 亚洲精品在线网站| 色又黄又爽网站www久久| 免费观看30秒视频久久| 国产精品久久久久久久浪潮网站| 欧美性淫爽ww久久久久无| 激情文学综合插| 亚洲色图在线播放| 精品日韩一区二区三区| 色www精品视频在线观看| 加勒比av一区二区| 亚洲精品日产精品乱码不卡| 欧美精品一区二区在线播放| 色综合天天做天天爱| 极品销魂美女一区二区三区| 亚洲美女视频一区| 337p日本欧洲亚洲大胆精品| 91电影在线观看| 成人免费视频caoporn| 日本不卡一二三| 亚洲一区二区三区在线| 中文字幕欧美国产| 精品国产123| 欧美久久久一区| 色婷婷久久综合| 成人一级视频在线观看| 日韩成人av影视| 亚洲欧美日韩国产另类专区| 精品国产99国产精品| 91精品国产入口在线| 在线免费观看成人短视频| 成人晚上爱看视频| 国产一区二区精品在线观看| 婷婷综合另类小说色区| 亚洲欧美中日韩| 91麻豆精品国产无毒不卡在线观看| 99久久精品情趣| jizz一区二区| 成人av免费在线播放| 国产高清在线观看免费不卡| 精品一区二区三区在线观看国产 | 国产精品久久久久久久久动漫| 欧美电影在哪看比较好| 欧美色手机在线观看| 欧美性极品少妇| 在线一区二区观看| 91亚洲国产成人精品一区二区三| 懂色av中文一区二区三区| 国产乱国产乱300精品| 国产麻豆精品久久一二三| 国产一区二区在线看| 免费视频一区二区| 久久99精品一区二区三区| 蜜桃久久久久久| 精久久久久久久久久久| 国产主播一区二区| 高清国产一区二区三区| 丁香婷婷深情五月亚洲| 不卡电影一区二区三区| voyeur盗摄精品| 色哟哟亚洲精品| 欧美丝袜自拍制服另类| 欧美精品丝袜中出| 欧美一区二区三区喷汁尤物| 精品三级在线看| 欧美激情综合五月色丁香| 国产欧美日韩精品一区| 国产精品每日更新在线播放网址| 中文字幕欧美日本乱码一线二线| 亚洲视频电影在线| 亚洲一区二区在线免费观看视频| 日韩激情av在线| 国产一区二区三区四| 99精品在线观看视频| 欧美日韩午夜影院| 精品国产精品一区二区夜夜嗨 | 精品久久久久av影院| 久久综合九色综合97_久久久| 国产目拍亚洲精品99久久精品| 亚洲欧洲av色图| 免费成人深夜小野草| 国产a精品视频| 欧美性感一区二区三区| 亚洲精品在线网站| 亚洲综合色成人| 国产一区二区女| 一道本成人在线| 久久综合九色综合97婷婷| 一区二区三区美女视频| 韩国欧美一区二区| 欧美三级欧美一级| 欧美电视剧免费观看| 中文字幕一区二| 在线观看av一区| 欧美电影免费观看高清完整版在| 综合久久国产九一剧情麻豆| 蓝色福利精品导航| 欧美亚洲国产一区在线观看网站| 色老汉av一区二区三区| 欧美一区二区三区播放老司机| 最近日韩中文字幕| 久久国产精品露脸对白| 欧美亚洲日本一区| 中文字幕免费在线观看视频一区| 日韩av一区二区在线影视| 不卡av在线免费观看| 精品国产99国产精品| 日韩精品亚洲一区| 91天堂素人约啪| 国产欧美一区二区精品性色超碰| 人人精品人人爱| 在线一区二区三区四区五区| 国产精品视频线看| 国产成人精品免费| 欧美成人综合网站| 日韩黄色片在线观看| 欧美在线一区二区三区| 亚洲人成人一区二区在线观看| 国产不卡视频在线播放| 精品国内二区三区| 蜜臀av性久久久久蜜臀av麻豆| 欧美性色欧美a在线播放| 国产精品传媒视频| 成人午夜私人影院| 国产精品水嫩水嫩| 成人美女视频在线观看18| 久久美女艺术照精彩视频福利播放| 久久精品国产亚洲a| 精品少妇一区二区| 国产伦理精品不卡| 久久久久国产精品免费免费搜索| 国产成人综合亚洲网站|