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

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

?? rpc_key.c

?? TCG軟件棧 linux系統上使用 為可信應用軟件提供和 TPM通信的 接口 其網站上有很多關于使用此軟件的測試用例
?? C
字號:
/* * Licensed Materials - Property of IBM * * trousers - An open source TCG Software Stack * * (C) Copyright International Business Machines Corp. 2004-2007 * */#include <stdlib.h>#include <stdio.h>#include <string.h>#include <assert.h>#include "trousers/tss.h"#include "trousers/trousers.h"#include "trousers_types.h"#include "spi_utils.h"#include "capabilities.h"#include "tsplog.h"#include "hosttable.h"#include "tcsd_wrap.h"#include "obj.h"#include "rpc_tcstp_tsp.h"TSS_RESULTRPC_LoadKeyByBlob_TP(struct host_table_entry *hte,		      TCS_KEY_HANDLE hUnwrappingKey,	/* in */		      UINT32 cWrappedKeyBlobSize,	/* in */		      BYTE * rgbWrappedKeyBlob,	/* in */		      TPM_AUTH * pAuth,	/* in, out */		      TCS_KEY_HANDLE * phKeyTCSI,	/* out */		      TCS_KEY_HANDLE * phKeyHMAC)	/* out */{	TSS_RESULT result;	int i;	initData(&hte->comm, 5);	hte->comm.hdr.u.ordinal = TCSD_ORD_LOADKEYBYBLOB;	LogDebugFn("IN: TCS Context: 0x%x", hte->tcsContext);	if (setData(TCSD_PACKET_TYPE_UINT32, 0, &hte->tcsContext, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_UINT32, 1, &hUnwrappingKey, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_UINT32, 2, &cWrappedKeyBlobSize, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_PBYTE, 3, rgbWrappedKeyBlob, cWrappedKeyBlobSize, &hte->comm))			return TSPERR(TSS_E_INTERNAL_ERROR);	if (pAuth != NULL) {		if (setData(TCSD_PACKET_TYPE_AUTH, 4, pAuth, 0, &hte->comm))			return TSPERR(TSS_E_INTERNAL_ERROR);	}	result = sendTCSDPacket(hte);	if (result == TSS_SUCCESS)		result = hte->comm.hdr.u.result;	if (result == TSS_SUCCESS) {		i = 0;		if (pAuth != NULL) {			if (getData(TCSD_PACKET_TYPE_AUTH, i++, pAuth, 0, &hte->comm))				result = TSPERR(TSS_E_INTERNAL_ERROR);		}		if (getData(TCSD_PACKET_TYPE_UINT32, i++, phKeyTCSI, 0, &hte->comm))			result = TSPERR(TSS_E_INTERNAL_ERROR);		if (getData(TCSD_PACKET_TYPE_UINT32, i++, phKeyHMAC, 0, &hte->comm))			result = TSPERR(TSS_E_INTERNAL_ERROR);		LogDebugFn("OUT: TCS key handle: 0x%x, TPM key slot: 0x%x", *phKeyTCSI,			   *phKeyHMAC);	}	return result;}TSS_RESULTRPC_EvictKey_TP(struct host_table_entry *hte,		 TCS_KEY_HANDLE hKey)	/* in */{	TSS_RESULT result;	initData(&hte->comm, 2);	hte->comm.hdr.u.ordinal = TCSD_ORD_EVICTKEY;	LogDebugFn("TCS Context: 0x%x", hte->tcsContext);	if (setData(TCSD_PACKET_TYPE_UINT32, 0, &hte->tcsContext, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_UINT32, 1, &hKey, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	result = sendTCSDPacket(hte);	if (result == TSS_SUCCESS)		result = hte->comm.hdr.u.result;	return result;}TSS_RESULTRPC_CreateWrapKey_TP(struct host_table_entry *hte,		      TCS_KEY_HANDLE hWrappingKey,	/* in */		      TCPA_ENCAUTH *KeyUsageAuth,	/* in */		      TCPA_ENCAUTH *KeyMigrationAuth,	/* in */		      UINT32 keyInfoSize,	/* in */		      BYTE * keyInfo,	/* in */		      UINT32 * keyDataSize,	/* out */		      BYTE ** keyData,	/* out */		      TPM_AUTH * pAuth)	/* in, out */{	TSS_RESULT result;	initData(&hte->comm, 7);	hte->comm.hdr.u.ordinal = TCSD_ORD_CREATEWRAPKEY;	LogDebugFn("TCS Context: 0x%x", hte->tcsContext);	if (setData(TCSD_PACKET_TYPE_UINT32, 0, &hte->tcsContext, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_UINT32, 1, &hWrappingKey, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_ENCAUTH, 2, KeyUsageAuth, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_ENCAUTH, 3, KeyMigrationAuth, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_UINT32, 4, &keyInfoSize, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_PBYTE, 5, keyInfo, keyInfoSize, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (pAuth) {		if (setData(TCSD_PACKET_TYPE_AUTH, 6, pAuth, 0, &hte->comm))			return TSPERR(TSS_E_INTERNAL_ERROR);	}	result = sendTCSDPacket(hte);	if (result == TSS_SUCCESS)		result = hte->comm.hdr.u.result;	if (result == TSS_SUCCESS) {		if (getData(TCSD_PACKET_TYPE_UINT32, 0, keyDataSize, 0, &hte->comm)) {			result = TSPERR(TSS_E_INTERNAL_ERROR);			goto done;		}		*keyData = (BYTE *) malloc(*keyDataSize);		if (*keyData == NULL) {			LogError("malloc of %u bytes failed.", *keyDataSize);			result = TSPERR(TSS_E_OUTOFMEMORY);			goto done;		}		if (getData(TCSD_PACKET_TYPE_PBYTE, 1, *keyData, *keyDataSize, &hte->comm)) {			free(*keyData);			result = TSPERR(TSS_E_INTERNAL_ERROR);			goto done;		}		if (pAuth) {			if (getData(TCSD_PACKET_TYPE_AUTH, 2, pAuth, 0, &hte->comm)) {				free(*keyData);				result = TSPERR(TSS_E_INTERNAL_ERROR);				goto done;			}		}	}done:	return result;}TSS_RESULTRPC_GetPubKey_TP(struct host_table_entry *hte,		  TCS_KEY_HANDLE hKey,	/* in */		  TPM_AUTH * pAuth,	/* in, out */		  UINT32 * pcPubKeySize,	/* out */		  BYTE ** prgbPubKey)	/* out */{	TSS_RESULT result;	int i;	initData(&hte->comm, 3);	hte->comm.hdr.u.ordinal = TCSD_ORD_GETPUBKEY;	LogDebugFn("TCS Context: 0x%x", hte->tcsContext);	if (setData(TCSD_PACKET_TYPE_UINT32, 0, &hte->tcsContext, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_UINT32, 1, &hKey, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (pAuth != NULL) {		if (setData(TCSD_PACKET_TYPE_AUTH, 2, pAuth, 0, &hte->comm))			return TSPERR(TSS_E_INTERNAL_ERROR);	}	result = sendTCSDPacket(hte);	if (result == TSS_SUCCESS)		result = hte->comm.hdr.u.result;	i = 0;	if (result == TSS_SUCCESS) {		if (pAuth != NULL) {			if (getData(TCSD_PACKET_TYPE_AUTH, i++, pAuth, 0, &hte->comm)) {				result = TSPERR(TSS_E_INTERNAL_ERROR);				goto done;			}		}		if (getData(TCSD_PACKET_TYPE_UINT32, i++, pcPubKeySize, 0, &hte->comm)) {			result = TSPERR(TSS_E_INTERNAL_ERROR);			goto done;		}		*prgbPubKey = (BYTE *) malloc(*pcPubKeySize);		if (*prgbPubKey == NULL) {			LogError("malloc of %u bytes failed.", *pcPubKeySize);			result = TSPERR(TSS_E_OUTOFMEMORY);			goto done;		}		if (getData(TCSD_PACKET_TYPE_PBYTE, i++, *prgbPubKey, *pcPubKeySize, &hte->comm)) {			free(*prgbPubKey);			result = TSPERR(TSS_E_INTERNAL_ERROR);		}	}done:	return result;}TSS_RESULTRPC_TerminateHandle_TP(struct host_table_entry *hte,			TCS_AUTHHANDLE handle)	/* in */{	TSS_RESULT result;	initData(&hte->comm, 2);	hte->comm.hdr.u.ordinal = TCSD_ORD_TERMINATEHANDLE;	LogDebugFn("TCS Context: 0x%x", hte->tcsContext);	if (setData(TCSD_PACKET_TYPE_UINT32, 0, &hte->tcsContext, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_UINT32, 1, &handle, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	result = sendTCSDPacket(hte);	if (result == TSS_SUCCESS)		result = hte->comm.hdr.u.result;	return result;}TSS_RESULTRPC_OwnerReadInternalPub_TP(struct host_table_entry *hte,			     TCS_KEY_HANDLE hKey,	/* in */			     TPM_AUTH * pOwnerAuth,	/* in, out */			     UINT32 * punPubKeySize,	/* out */			     BYTE ** ppbPubKeyData)	/* out */{	TSS_RESULT result;	initData(&hte->comm, 3);	hte->comm.hdr.u.ordinal = TCSD_ORD_OWNERREADINTERNALPUB;	LogDebugFn("TCS Context: 0x%x", hte->tcsContext);	if (setData(TCSD_PACKET_TYPE_UINT32, 0, &hte->tcsContext, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_UINT32, 1, &hKey, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (pOwnerAuth != NULL) {		if (setData(TCSD_PACKET_TYPE_AUTH, 2, pOwnerAuth, 0, &hte->comm))			return TSPERR(TSS_E_INTERNAL_ERROR);	}	result = sendTCSDPacket(hte);	if (result == TSS_SUCCESS)		result = hte->comm.hdr.u.result;	if (result == TSS_SUCCESS) {		if (getData(TCSD_PACKET_TYPE_AUTH, 0, pOwnerAuth, 0, &hte->comm))			result = TSPERR(TSS_E_INTERNAL_ERROR);		if (getData(TCSD_PACKET_TYPE_UINT32, 1, punPubKeySize, 0, &hte->comm))			result = TSPERR(TSS_E_INTERNAL_ERROR);		*ppbPubKeyData = (BYTE *) malloc(*punPubKeySize);		if (*ppbPubKeyData == NULL) {			LogError("malloc of %u bytes failed.", *punPubKeySize);			return TSPERR(TSS_E_OUTOFMEMORY);		}		if (getData(TCSD_PACKET_TYPE_PBYTE, 2, *ppbPubKeyData, *punPubKeySize, 			    &hte->comm)) {			free(*ppbPubKeyData);			result = TSPERR(TSS_E_INTERNAL_ERROR);		}	}	return result;}/* TSS 1.2-only interfaces */#ifdef TSS_BUILD_TSS12TSS_RESULTRPC_KeyControlOwner_TP(struct host_table_entry *hte,		// in			TCS_KEY_HANDLE     hKey,		// in			UINT32             ulPublicInfoLength,	// in			BYTE*              rgbPublicInfo,	// in			UINT32             attribName,		// in			TSS_BOOL           attribValue,		// in			TPM_AUTH*          pOwnerAuth,		// in, out			TSS_UUID*          pUuidData)		// out{	TSS_RESULT result;	initData(&hte->comm, 7);	hte->comm.hdr.u.ordinal = TCSD_ORD_KEYCONTROLOWNER;	LogDebugFn("TCS Context: 0x%x", hte->tcsContext);	if (setData(TCSD_PACKET_TYPE_UINT32, 0, &hte->tcsContext, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_UINT32, 1, &hKey, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_UINT32, 2, &ulPublicInfoLength, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_PBYTE, 3, rgbPublicInfo, ulPublicInfoLength, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_UINT32, 4, &attribName, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_BOOL, 5, &attribValue, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (pOwnerAuth != NULL) {		if (setData(TCSD_PACKET_TYPE_AUTH, 6, pOwnerAuth, 0, &hte->comm))			return TSPERR(TSS_E_INTERNAL_ERROR);	}	result = sendTCSDPacket(hte);	if (result == TSS_SUCCESS)		result = hte->comm.hdr.u.result;	if (result == TSS_SUCCESS) {		if (getData(TCSD_PACKET_TYPE_AUTH, 0, pOwnerAuth, 0, &hte->comm))			result = TSPERR(TSS_E_INTERNAL_ERROR);		if (getData(TCSD_PACKET_TYPE_UUID, 1, pUuidData, 0, &hte->comm))			result = TSPERR(TSS_E_INTERNAL_ERROR);	}	return result;}#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品91久久久中77777| 国产一区二区三区香蕉| 一本久久综合亚洲鲁鲁五月天| 国产日韩影视精品| 国产精品99久久久久久久女警| 亚洲精品在线免费播放| 国产ts人妖一区二区| 国产精品天干天干在线综合| 99这里都是精品| 亚洲精品久久久蜜桃| 欧美三级一区二区| 五月天激情综合| 精品国产乱码久久久久久闺蜜 | 日韩欧美一区二区视频| 久草这里只有精品视频| 国产视频一区二区在线观看| 不卡av在线网| 五月激情综合婷婷| 久久久一区二区| 色爱区综合激月婷婷| 奇米影视一区二区三区小说| 国产网站一区二区| 色呦呦国产精品| 精品一区二区在线播放| 亚洲视频一区二区在线观看| 欧美美女视频在线观看| 国产黄色91视频| 亚洲国产精品一区二区尤物区| 欧美大度的电影原声| 成人午夜精品一区二区三区| 亚洲午夜久久久久久久久久久| 日韩亚洲欧美一区二区三区| 播五月开心婷婷综合| 日韩**一区毛片| 中文字幕亚洲精品在线观看| 欧美妇女性影城| 99久久国产免费看| 九色porny丨国产精品| 亚洲欧美日韩一区二区三区在线观看| 欧美一级日韩一级| 91婷婷韩国欧美一区二区| 裸体歌舞表演一区二区| 一区二区三区日韩精品视频| 久久免费视频一区| 欧美日韩精品系列| 成人美女视频在线观看18| 蜜臀久久久99精品久久久久久| 亚洲人成网站影音先锋播放| 亚洲精品在线免费观看视频| 欧美日韩精品一区二区在线播放| 成人免费毛片aaaaa**| 美女在线视频一区| 亚洲电影在线播放| 国产精品不卡视频| 丝瓜av网站精品一区二区| 国产精品福利一区二区三区| 精品美女被调教视频大全网站| 在线观看日韩精品| av综合在线播放| 高清beeg欧美| 国产一区二区三区免费| 美女被吸乳得到大胸91| 日韩av一区二区三区四区| 一区二区三区小说| 亚洲欧美色综合| 中文字幕一区二区在线播放| 久久蜜桃香蕉精品一区二区三区| 日韩午夜在线影院| 欧美电影一区二区三区| 欧美午夜片在线观看| 97se亚洲国产综合自在线观| 99精品黄色片免费大全| 丰满亚洲少妇av| 国产成人亚洲综合a∨婷婷| 国内精品写真在线观看| 国产一区二区三区免费播放| 国产一区二三区好的| 韩国女主播一区二区三区| 毛片基地黄久久久久久天堂| 免费成人在线视频观看| 激情综合网最新| 国内成人免费视频| 国产传媒一区在线| 成人激情黄色小说| 99久久久免费精品国产一区二区| 成人精品一区二区三区中文字幕| 不卡的av在线| 欧美性受xxxx| 制服丝袜国产精品| 日韩欧美国产不卡| 久久久天堂av| 最新热久久免费视频| 一区二区三区日韩欧美| 天堂一区二区在线免费观看| 奇米一区二区三区av| 国产剧情av麻豆香蕉精品| 高清不卡在线观看| 色爱区综合激月婷婷| 欧美一区二区三区在线看| 欧美成人乱码一区二区三区| 日本一区二区免费在线| 亚洲免费电影在线| 亚洲.国产.中文慕字在线| 激情综合色综合久久| 成人性生交大片免费看中文网站| 91色porny在线视频| 欧美蜜桃一区二区三区| 国产色婷婷亚洲99精品小说| 亚洲人一二三区| 视频一区免费在线观看| 国产jizzjizz一区二区| 欧美性大战久久| 精品国产髙清在线看国产毛片| 欧美国产精品劲爆| 亚洲国产乱码最新视频| 国产精品夜夜爽| 欧美日韩久久一区| 国产欧美精品日韩区二区麻豆天美| 一区二区免费在线| 国产乱码精品一区二区三区忘忧草| 99精品桃花视频在线观看| 欧美一区二区三级| 综合久久国产九一剧情麻豆| 日韩经典中文字幕一区| 成人高清免费观看| 91精品国产综合久久久久久| 国产精品素人视频| 免费成人小视频| 国产欧美精品一区二区色综合| 香蕉成人伊视频在线观看| 粉嫩蜜臀av国产精品网站| 日韩一区二区三区高清免费看看| 日本一区二区三区免费乱视频| 亚洲精品日韩综合观看成人91| 正在播放一区二区| 亚洲伦理在线精品| 大白屁股一区二区视频| 日韩欧美国产麻豆| 最新成人av在线| 懂色一区二区三区免费观看| 欧美日韩在线播| ㊣最新国产の精品bt伙计久久| 亚洲四区在线观看| 成人h精品动漫一区二区三区| 在线播放/欧美激情| 亚洲精品videosex极品| 欧美精品自拍偷拍动漫精品| 色天天综合色天天久久| 久久噜噜亚洲综合| 日本不卡中文字幕| 欧美视频一区二区三区在线观看 | 婷婷久久综合九色综合伊人色| 成人激情午夜影院| 精品不卡在线视频| 美国欧美日韩国产在线播放| 欧美精选午夜久久久乱码6080| 亚洲九九爱视频| 91免费国产在线| 中文字幕亚洲电影| 99久久er热在这里只有精品15 | 欧美电影免费观看完整版| 一区二区三区资源| 色综合一个色综合| 亚洲丝袜美腿综合| 99久久精品免费看国产| 中文字幕一区视频| 91美女精品福利| 亚洲精品高清在线| 在线视频中文字幕一区二区| 国产精品美女久久久久久久久久久| 国产成人午夜精品影院观看视频 | 免费高清视频精品| 69堂国产成人免费视频| 水蜜桃久久夜色精品一区的特点 | 久久综合久久鬼色中文字| 六月婷婷色综合| 久久久综合激的五月天| 成人污污视频在线观看| 国产精品欧美一级免费| 成人av免费网站| 亚洲精品国产无天堂网2021 | 欧美色图一区二区三区| 一区二区三区.www| 欧美日韩亚州综合| 日本欧美加勒比视频| 欧美成人免费网站| 国产999精品久久久久久| 亚洲国产精品嫩草影院| 91精品国模一区二区三区| 精品一区二区三区在线观看国产| 久久人人97超碰com| 99久久综合狠狠综合久久| 亚洲精品视频在线看| 欧美日韩激情在线| 国产在线不卡一区| 亚洲人成精品久久久久| 欧美日韩精品欧美日韩精品一 | 一区二区三区在线免费视频| 欧美精品久久99| 国产精品123|