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

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

?? rpc_ek.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_CreateEndorsementKeyPair_TP(struct host_table_entry *hte,					     TCPA_NONCE antiReplay,	/* in */					     UINT32 endorsementKeyInfoSize,	/* in */					     BYTE * endorsementKeyInfo,	/* in */					     UINT32 * endorsementKeySize,	/* out */					     BYTE ** endorsementKey,	/* out */					     TCPA_DIGEST * checksum	/* out */    ) {	TSS_RESULT result;	initData(&hte->comm, 4);	hte->comm.hdr.u.ordinal = TCSD_ORD_CREATEENDORSEMENTKEYPAIR;	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_NONCE, 1, &antiReplay, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_UINT32, 2, &endorsementKeyInfoSize, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_PBYTE, 3, endorsementKeyInfo, endorsementKeyInfoSize, &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, endorsementKeySize, 0, &hte->comm)) {			result = TSPERR(TSS_E_INTERNAL_ERROR);			goto done;		}		*endorsementKey = (BYTE *) malloc(*endorsementKeySize);		if (*endorsementKey == NULL) {			LogError("malloc of %u bytes failed.", *endorsementKeySize);			result = TSPERR(TSS_E_OUTOFMEMORY);			goto done;		}		if (getData(TCSD_PACKET_TYPE_PBYTE, 1, *endorsementKey, *endorsementKeySize, &hte->comm)) {			free(*endorsementKey);			result = TSPERR(TSS_E_INTERNAL_ERROR);			goto done;		}		if (getData(TCSD_PACKET_TYPE_DIGEST, 2, &(checksum->digest), 0, &hte->comm)) {			free(*endorsementKey);			result = TSPERR(TSS_E_INTERNAL_ERROR);		}	}done:	return result;}TSS_RESULTRPC_ReadPubek_TP(struct host_table_entry *hte,			      TCPA_NONCE antiReplay,	/* in */			      UINT32 * pubEndorsementKeySize,	/* out */			      BYTE ** pubEndorsementKey,	/* out */			      TCPA_DIGEST * checksum	/* out */    ) {	TSS_RESULT result;	initData(&hte->comm, 2);	hte->comm.hdr.u.ordinal = TCSD_ORD_READPUBEK;	LogDebugFn("TCS Context: 0x%x", hte->tcsContext);	/*      &hte->comm.numParms = 2; */	if (setData(TCSD_PACKET_TYPE_UINT32, 0, &hte->tcsContext, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_NONCE, 1, &antiReplay, 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, pubEndorsementKeySize, 0, &hte->comm)) {			result = TSPERR(TSS_E_INTERNAL_ERROR);			goto done;		}		*pubEndorsementKey = (BYTE *) malloc(*pubEndorsementKeySize);		if (*pubEndorsementKey == NULL) {			LogError("malloc of %u bytes failed.", *pubEndorsementKeySize);			result = TSPERR(TSS_E_OUTOFMEMORY);			goto done;		}		if (getData(TCSD_PACKET_TYPE_PBYTE, 1, *pubEndorsementKey, *pubEndorsementKeySize, &hte->comm)) {			free(*pubEndorsementKey);			result = TSPERR(TSS_E_INTERNAL_ERROR);			goto done;		}		if (getData(TCSD_PACKET_TYPE_DIGEST, 2, &(checksum->digest), 0, &hte->comm)) {			free(*pubEndorsementKey);			result = TSPERR(TSS_E_INTERNAL_ERROR);		}	}done:	return result;}TSS_RESULTRPC_DisablePubekRead_TP(struct host_table_entry *hte,				     TPM_AUTH * ownerAuth	/* in, out */    ) {	TSS_RESULT result;	initData(&hte->comm, 2);	hte->comm.hdr.u.ordinal = TCSD_ORD_DISABLEPUBEKREAD;	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_AUTH, 1, ownerAuth, 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, ownerAuth, 0, &hte->comm))			result = TSPERR(TSS_E_INTERNAL_ERROR);	}	return result;}TSS_RESULTRPC_OwnerReadPubek_TP(struct host_table_entry *hte,				   TPM_AUTH * ownerAuth,	/* in, out */				   UINT32 * pubEndorsementKeySize,	/* out */				   BYTE ** pubEndorsementKey	/* out */    ) {        TSS_RESULT result;	initData(&hte->comm, 2);        hte->comm.hdr.u.ordinal = TCSD_ORD_OWNERREADPUBEK;	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_AUTH, 1, ownerAuth, 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, ownerAuth, 0, &hte->comm)){			free(*pubEndorsementKey);                        result = TSPERR(TSS_E_INTERNAL_ERROR);		}                if (getData(TCSD_PACKET_TYPE_UINT32, 1, pubEndorsementKeySize, 0, &hte->comm)) {                        result = TSPERR(TSS_E_INTERNAL_ERROR);                        goto done;                }                *pubEndorsementKey = (BYTE *) malloc(*pubEndorsementKeySize);                if (*pubEndorsementKey == NULL) {                        LogError("malloc of %u bytes failed.", *pubEndorsementKeySize);                        result = TSPERR(TSS_E_OUTOFMEMORY);                        goto done;                }                if (getData(TCSD_PACKET_TYPE_PBYTE, 2, *pubEndorsementKey, *pubEndorsementKeySize, &hte->comm)) {                        free(*pubEndorsementKey);                        result = TSPERR(TSS_E_INTERNAL_ERROR);			goto done;                }        }done:	return result;}TSS_RESULTRPC_CreateRevocableEndorsementKeyPair_TP(struct host_table_entry *hte,					 TPM_NONCE antiReplay,		/* in */					 UINT32 endorsementKeyInfoSize,/* in */					 BYTE * endorsementKeyInfo,	/* in */					 TSS_BOOL genResetAuth,	/* in */					 TPM_DIGEST * eKResetAuth,	/* in, out */					 UINT32 * endorsementKeySize,	/* out */					 BYTE ** endorsementKey,	/* out */					 TPM_DIGEST * checksum)	/* out */{	TSS_RESULT result;	initData(&hte->comm, 6);	hte->comm.hdr.u.ordinal = TCSD_ORD_CREATEREVOCABLEENDORSEMENTKEYPAIR;	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_NONCE, 1, &antiReplay, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_UINT32, 2, &endorsementKeyInfoSize, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_PBYTE, 3, endorsementKeyInfo, endorsementKeyInfoSize, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_BOOL, 4, &genResetAuth, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	if (setData(TCSD_PACKET_TYPE_DIGEST, 5, eKResetAuth, 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_DIGEST, 0, &(eKResetAuth->digest), 0, &hte->comm)) {			result = TSPERR(TSS_E_INTERNAL_ERROR);			goto done;		}		if (getData(TCSD_PACKET_TYPE_UINT32, 1, endorsementKeySize, 0, &hte->comm)) {			result = TSPERR(TSS_E_INTERNAL_ERROR);			goto done;		}		*endorsementKey = (BYTE *) malloc(*endorsementKeySize);		if (*endorsementKey == NULL) {			LogError("malloc of %u bytes failed.", *endorsementKeySize);			result = TSPERR(TSS_E_OUTOFMEMORY);			goto done;		}		if (getData(TCSD_PACKET_TYPE_PBYTE, 2, *endorsementKey, *endorsementKeySize, &hte->comm)) {			free(*endorsementKey);			result = TSPERR(TSS_E_INTERNAL_ERROR);			goto done;		}		if (getData(TCSD_PACKET_TYPE_DIGEST, 3, &(checksum->digest), 0, &hte->comm)) {			free(*endorsementKey);			result = TSPERR(TSS_E_INTERNAL_ERROR);		}	}done:	return result;}TSS_RESULTRPC_RevokeEndorsementKeyPair_TP(struct host_table_entry *hte,				TPM_DIGEST *EKResetAuth)	/* in */{	TSS_RESULT result;	initData(&hte->comm, 2);	hte->comm.hdr.u.ordinal = TCSD_ORD_REVOKEENDORSEMENTKEYPAIR;	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_DIGEST, 1, EKResetAuth, 0, &hte->comm))		return TSPERR(TSS_E_INTERNAL_ERROR);	result = sendTCSDPacket(hte);	if (result == TSS_SUCCESS)		result = hte->comm.hdr.u.result;	return result;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲v中文字幕| 国产精品短视频| 久久久久久久久久美女| 国产精品国产a级| 国v精品久久久网| 欧美三级乱人伦电影| 久久天天做天天爱综合色| 亚洲精选免费视频| 国产在线精品国自产拍免费| 色综合视频在线观看| 日韩亚洲欧美中文三级| 亚洲人成伊人成综合网小说| 国产精品亚洲а∨天堂免在线| 欧美日韩一区二区三区四区 | 国产精品99久久久久久久vr| 久久亚洲一区二区三区四区| 国产乱一区二区| 中文字幕成人av| 久久精品国产99国产| 欧美图片一区二区三区| 国产精品美女久久久久久2018| 免费看精品久久片| 欧美日本在线看| 亚洲一区二区在线免费看| 97久久人人超碰| 国产精品久久久久久久久快鸭| 色欧美片视频在线观看在线视频| 天天综合网天天综合色| 欧美视频日韩视频在线观看| 日韩成人一级片| 欧美美女bb生活片| 午夜精品久久久久久久蜜桃app| 日韩欧美成人一区| 美女一区二区视频| 日韩一区二区三区电影| 高清国产一区二区| 亚洲超丰满肉感bbw| 欧美精品一区二区久久久| 精品在线播放免费| 久久久久久亚洲综合影院红桃 | 中文字幕乱码亚洲精品一区 | 99久久婷婷国产综合精品电影| 亚洲一区二区av在线| 国产亚洲成年网址在线观看| 国产精品亚洲人在线观看| 亚洲影院理伦片| 国产精品天天看| 91精品国产入口| 国产一区不卡视频| 香蕉久久夜色精品国产使用方法| 国产日韩欧美高清在线| 91麻豆精品国产综合久久久久久| 欧美日韩中文国产| 国产成人免费在线视频| 国产精品久久久久久久久久免费看| 欧美福利一区二区| 色婷婷综合久久久中文字幕| 国产精品一区二区无线| 麻豆精品视频在线| 亚洲成人精品影院| 亚洲色图欧美激情| 欧美日本视频在线| 在线观看一区不卡| 日本欧美一区二区在线观看| 亚洲精品视频免费看| 国产精品乱码久久久久久| 26uuu色噜噜精品一区| 日韩一级二级三级精品视频| 欧美久久久久久久久久| 在线观看一区二区视频| 91麻豆.com| 久久福利视频一区二区| 国产一区二区电影| 国产精品免费观看视频| 日韩免费观看高清完整版在线观看| 不卡在线视频中文字幕| 亚洲自拍偷拍麻豆| 亚洲欧美日韩国产综合| 亚洲欧美偷拍三级| 曰韩精品一区二区| 亚洲综合成人在线视频| 亚洲柠檬福利资源导航| 亚洲日本丝袜连裤袜办公室| 中文字幕日韩精品一区| 日韩视频免费观看高清完整版 | 色94色欧美sute亚洲线路一ni| 日韩激情中文字幕| 国产精品成人网| 中文字幕一区二区不卡| 一区二区中文视频| 一区二区日韩av| 国产欧美在线观看一区| 国产欧美日韩综合| 国产精品传媒入口麻豆| 亚洲婷婷国产精品电影人久久| √…a在线天堂一区| 一区二区三区高清| 午夜精品视频一区| 久久99久久精品| 成人妖精视频yjsp地址| 久久精品免费观看| 国产精品白丝jk黑袜喷水| 成人午夜激情影院| 在线视频欧美区| 欧美一区二区三区免费观看视频| 欧美大片一区二区| 欧美高清一级片在线观看| 亚洲视频资源在线| 丝袜亚洲另类欧美综合| 国产在线精品一区二区夜色| 亚洲电影在线免费观看| 亚洲欧美激情插| 午夜精品免费在线| 国产精品亚洲一区二区三区妖精| gogo大胆日本视频一区| 成人网在线免费视频| 欧美亚洲一区二区在线观看| 欧美一区二区不卡视频| 国产欧美日韩一区二区三区在线观看| 亚洲精品亚洲人成人网在线播放| 蜜臂av日日欢夜夜爽一区| 高清不卡在线观看| 欧美性极品少妇| 久久精品男人的天堂| 一区二区三区 在线观看视频| 久久精品国产77777蜜臀| 99这里只有精品| 日韩女优av电影| 一区二区三区精品视频在线| 精品亚洲国产成人av制服丝袜 | 亚洲国产日韩综合久久精品| 国产自产v一区二区三区c| 色婷婷综合五月| 国产欧美日韩在线观看| 免费观看一级特黄欧美大片| 91女厕偷拍女厕偷拍高清| 精品福利一二区| 午夜精品福利一区二区三区av| 福利电影一区二区三区| 日韩一区二区中文字幕| 一区二区三区日韩精品视频| 国产99久久久国产精品潘金网站| 欧美伦理电影网| 亚洲欧美另类小说| 春色校园综合激情亚洲| 精品美女在线观看| 久久久99精品久久| 日韩av中文在线观看| 色av综合在线| 亚洲男帅同性gay1069| 成人国产精品免费观看| 欧美精品一区二区三区很污很色的| 石原莉奈在线亚洲二区| 欧美写真视频网站| 一区二区三区中文字幕电影| 粉嫩av一区二区三区在线播放| 精品国产免费一区二区三区四区| 天堂va蜜桃一区二区三区| 欧洲生活片亚洲生活在线观看| 综合婷婷亚洲小说| 丁香激情综合五月| 日本一区二区三区电影| 国产成人aaa| 国产人伦精品一区二区| 国产精品综合在线视频| 久久久久国产精品麻豆ai换脸| 久久精品国产久精国产爱| 日韩欧美第一区| 九九**精品视频免费播放| 日韩欧美一级精品久久| 蜜桃在线一区二区三区| 69堂国产成人免费视频| 日韩av在线播放中文字幕| 6080国产精品一区二区| 三级亚洲高清视频| 日韩一区二区免费电影| 美女爽到高潮91| 精品理论电影在线| 国产美女娇喘av呻吟久久| 久久免费的精品国产v∧| 国产福利一区二区三区视频在线| 久久久精品影视| 暴力调教一区二区三区| 亚洲伦在线观看| 在线免费观看成人短视频| 亚洲国产一区二区视频| 91精品国产欧美一区二区| 麻豆中文一区二区| 久久日韩粉嫩一区二区三区| 国产91色综合久久免费分享| 中文字幕综合网| 欧美三级日韩在线| 老色鬼精品视频在线观看播放| 久久久www免费人成精品| 91色九色蝌蚪| 午夜久久久久久| 国产日韩欧美精品一区| 色婷婷av一区| 麻豆国产精品一区二区三区| 国产欧美一区二区三区沐欲|