123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483 |
- /*
- * Copyright (C) 2011-2017 Intel Corporation. All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- *
- * * Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * * 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.
- * * Neither the name of Intel Corporation nor the names of its
- * contributors may be used to endorse or promote products derived
- * from this software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
- * "AS IS" AND ANY EXPRESS 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 COPYRIGHT
- * OWNER OR 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.
- *
- */
- #ifdef DBG_LOG
- #include "oal/oal.h"
- #include <time.h>
- #include <stdio.h>
- #include <stdarg.h>
- #include <assert.h>
- #include <ctype.h>
- #include <se_stdio.h>
- #include <se_string.h>
- #include "se_thread.h"
- #include "type_length_value.h"
- #include "aeerror.h"
- #include "aesm_error.h"
- #include "sgx_error.h"
- static int aesm_trace_level = TRACE_LOG_LEVEL;
- static int at_start=1;
- se_mutex_t cs;
- static ae_error_t init_log_file(void)
- {
- char filename[MAX_PATH];
- ae_error_t err = aesm_get_pathname(FT_PERSISTENT_STORAGE, AESM_DBG_LOG_FID, filename, MAX_PATH);
- if(err != AE_SUCCESS)
- return err;
- return AE_SUCCESS;
- }
- #include <string>
- using namespace std;
- static const char *get_sgx_status_t_string(sgx_status_t status);
- static const char *get_ae_error_t_string(ae_error_t ae_error);
- static const char *get_aesm_error_t_string(aesm_error_t aesm_error);
- static const char *get_tlv_enum_type_t_string(uint8_t type);
- const char *support_tags[] = {
- "sgx",
- "aesm",//matching longer tag before shorter one so aesm should be arranged before ae
- "ae",
- "tlv"
- };
- #define COUNT_TAGS (sizeof(support_tags)/sizeof(support_tags[0]))
- #define TAG_SGX 0
- #define TAG_AESM 1
- #define TAG_AE 2
- #define TAG_TLV 3
- #define MAX_BUF_SIZE 4096
- std::string internal_log_msg_trans(const std::string& s)
- {
- std::string output;
- size_t i;
- const char *p = s.c_str();
- for (i = 0; i < s.length(); ++i){
- if (p[i] == '('){//begin of tag
- size_t start = i + 1;
- while (isspace(p[start]))start++;//skip all space
- int j;
- for (j = 0; j < COUNT_TAGS; ++j){
- int tag_len = strlen(support_tags[j]);
- if (strncmp(p + start, support_tags[j], tag_len) == 0){
- start += tag_len;
- break;
- }
- }
- if (j < COUNT_TAGS){//found a potential tag
- while (isspace(p[start]))start++;//skip all space after tag
- if ((p[start] == '-' || p[start] == '+') && isdigit(p[start + 1]) ||
- isdigit(p[start])){
- int number = strtol(p + start,NULL, 0);
- switch (j){
- case TAG_SGX:
- output += "(sgx_status_t:";
- output += get_sgx_status_t_string((sgx_status_t)number);
- output += ":";
- break;
- case TAG_AESM:
- output += "(aesm_error_t:";
- output += get_aesm_error_t_string((aesm_error_t)number);
- output += ":";
- break;
- case TAG_AE:
- output += "(ae_error_t:";
- output += get_ae_error_t_string((ae_error_t)number);
- output += ":";
- break;
- case TAG_TLV:
- output += "(TLV:";
- output += get_tlv_enum_type_t_string((uint8_t)number);
- output += ":";
- break;
- default:
- output += "(Unknown type:";
- break;
- }
- i = start-1;
- }
- else{
- output += p[i];
- }
- }
- else{//not found, keep original flags
- output += p[i];
- }
- }
- else{
- output += p[i];
- }
- }
- return output;
- }
- #define TIME_BUF_SIZE 100
- void aesm_internal_log(const char *file_name, int line_no, const char *funname, int level, const char *format, ...)
- {
- if(level <= aesm_trace_level){
- if(at_start){
- at_start=0;
- se_mutex_init(&cs);
- init_log_file();
- }
- char filename[MAX_PATH];
- ae_error_t err = aesm_get_cpathname(FT_PERSISTENT_STORAGE, AESM_DBG_LOG_FID, filename, MAX_PATH);
- if(err != AE_SUCCESS)
- return;
- FILE *logfile = NULL;
- se_mutex_lock(&cs);
- logfile = fopen(filename, "a+");
- if(logfile == NULL){
- se_mutex_unlock(&cs);
- return;
- }
- time_t t;
- struct tm time_info;
- va_list varg;
- char time_buf[TIME_BUF_SIZE];
- time(&t);
- struct tm *temp_time_info;
- temp_time_info = localtime(&t);
- memcpy_s(&time_info, sizeof(time_info), temp_time_info, sizeof(*temp_time_info));
- if(strftime(time_buf, TIME_BUF_SIZE, "%c", &time_info)!=0){
- fprintf(logfile, "[%s|%d|%s|%s]",file_name, line_no, funname, time_buf);
- }else{
- fprintf(logfile, "[%s|%d|%s]",file_name, line_no, funname);
- }
- va_start(varg, format);
- char message_buf[MAX_BUF_SIZE];
- vsnprintf(message_buf, MAX_BUF_SIZE-1, format, varg);
- va_end(varg);
- std::string input_message = message_buf;
- std::string output_message = internal_log_msg_trans(input_message);
- fprintf(logfile, "%s\n", output_message.c_str());
- fflush(logfile);
- fclose(logfile);
- se_mutex_unlock(&cs);
- }
- }
- void aesm_set_log_level(int level)
- {
- aesm_trace_level = level;
- }
- static char half_byte_to_char(int x)
- {
- assert(0<=x&&x<=0xF);
- if(0<=x&&x<=9)return (char)('0'+x);
- else return (char)('A'+x-10);
- }
- void aesm_dbg_format_hex(const uint8_t *data, uint32_t data_len, char *out_buf, uint32_t buf_size)
- {
- uint32_t i;
- assert(buf_size>0);
- if(data_len==0){
- out_buf[0]='\0';
- return;
- }
- if(buf_size/3>=data_len){
- for(i=0;i<data_len;i++){
- int low=data[i]&0xF;
- int high=(data[i]>>4)&0xF;
- out_buf[i*3]=half_byte_to_char(high);
- out_buf[i*3+1]=half_byte_to_char(low);
- out_buf[i*3+2]=' ';
- }
- out_buf[data_len*3-1]='\0';
- }else if(buf_size>10){
- uint32_t tcount=buf_size/3-1;
- uint32_t off;
- uint32_t ecount=tcount/2,bcount=tcount-ecount;
- for(i=0;i<bcount;i++){
- int low=data[i]&0xF;
- int high=(data[i]>>4)&0xF;
- out_buf[i*3]=half_byte_to_char(high);
- out_buf[i*3+1]=half_byte_to_char(low);
- out_buf[i*3+2]=' ';
- }
- out_buf[i*3]=out_buf[i*3+1]=out_buf[i*3+2]='.';
- off=i*3+3;
- for(i=0;i<ecount;i++){
- int low=data[data_len-ecount+i]&0xF;
- int high=(data[data_len-ecount+i]>>4)&0xF;
- out_buf[off+i*3]=half_byte_to_char(high);
- out_buf[off+i*3+1]=half_byte_to_char(low);
- out_buf[off+i*3+2]=' ';
- }
- out_buf[off+i*3-1]='\0';
- }else{
- for(i=0;/*i<data_len&&*/i<(buf_size-1)/3;i++){//checking for i<data_len is redundant since first if condition in the function has filtered it
- int low=data[i]&0xF;
- int high=(data[i]>>4)&0xF;
- out_buf[i*3]=half_byte_to_char(high);
- out_buf[i*3+1]=half_byte_to_char(low);
- out_buf[i*3+2]=' ';
- }
- out_buf[i*3]='\0';
- }
- }
- #define CASE_ENUM_RET_STRING(x) case x: return #x;
- //(tlv%d)
- static const char *get_tlv_enum_type_t_string(uint8_t type)
- {
- switch (type){
- CASE_ENUM_RET_STRING(TLV_CIPHER_TEXT)
- CASE_ENUM_RET_STRING(TLV_BLOCK_CIPHER_TEXT)
- CASE_ENUM_RET_STRING(TLV_BLOCK_CIPHER_INFO)
- CASE_ENUM_RET_STRING(TLV_MESSAGE_AUTHENTICATION_CODE)
- CASE_ENUM_RET_STRING(TLV_NONCE)
- CASE_ENUM_RET_STRING(TLV_EPID_GID)
- CASE_ENUM_RET_STRING(TLV_EPID_SIG_RL)
- CASE_ENUM_RET_STRING(TLV_EPID_GROUP_CERT)
- CASE_ENUM_RET_STRING(TLV_DEVICE_ID)
- CASE_ENUM_RET_STRING(TLV_PS_ID)
- CASE_ENUM_RET_STRING(TLV_EPID_JOIN_PROOF)
- CASE_ENUM_RET_STRING(TLV_EPID_SIG)
- CASE_ENUM_RET_STRING(TLV_EPID_MEMBERSHIP_CREDENTIAL)
- CASE_ENUM_RET_STRING(TLV_EPID_PSVN)
- CASE_ENUM_RET_STRING(TLV_QUOTE)
- CASE_ENUM_RET_STRING(TLV_X509_CERT_TLV)
- CASE_ENUM_RET_STRING(TLV_X509_CSR_TLV)
- CASE_ENUM_RET_STRING(TLV_ES_SELECTOR)
- CASE_ENUM_RET_STRING(TLV_ES_INFORMATION)
- CASE_ENUM_RET_STRING(TLV_FLAGS)
- CASE_ENUM_RET_STRING(TLV_QUOTE_SIG)
- CASE_ENUM_RET_STRING(TLV_PEK)
- CASE_ENUM_RET_STRING(TLV_SIGNATURE)
- CASE_ENUM_RET_STRING(TLV_PLATFORM_INFO)
- CASE_ENUM_RET_STRING(TLV_PWK2)
- CASE_ENUM_RET_STRING(TLV_SE_REPORT)
- default:
- return "Unknown TLV";
- }
- }
- //(ae%d)
- static const char *get_ae_error_t_string(ae_error_t ae_error)
- {
- switch (ae_error){
- CASE_ENUM_RET_STRING(AE_SUCCESS)
- CASE_ENUM_RET_STRING(AE_FAILURE)
- CASE_ENUM_RET_STRING(AE_ENCLAVE_LOST)
- CASE_ENUM_RET_STRING(OAL_PARAMETER_ERROR)
- CASE_ENUM_RET_STRING(OAL_PATHNAME_BUFFER_OVERFLOW_ERROR)
- CASE_ENUM_RET_STRING(OAL_FILE_ACCESS_ERROR)
- CASE_ENUM_RET_STRING(OAL_CONFIG_FILE_ERROR)
- CASE_ENUM_RET_STRING(OAL_NETWORK_UNAVAILABLE_ERROR)
- CASE_ENUM_RET_STRING(OAL_NETWORK_BUSY)
- CASE_ENUM_RET_STRING(OAL_NETWORK_RESEND_REQUIRED)
- CASE_ENUM_RET_STRING(OAL_PROXY_SETTING_ASSIST)
- CASE_ENUM_RET_STRING(OAL_THREAD_ERROR)
- CASE_ENUM_RET_STRING(OAL_THREAD_TIMEOUT_ERROR)
- CASE_ENUM_RET_STRING(AE_PSVN_UNMATCHED_ERROR)
- CASE_ENUM_RET_STRING(AE_SERVER_NOT_AVAILABLE)
- CASE_ENUM_RET_STRING(AE_INVALID_PARAMETER)
- CASE_ENUM_RET_STRING(AE_READ_RAND_ERROR)
- CASE_ENUM_RET_STRING(AE_OUT_OF_MEMORY_ERROR)
- CASE_ENUM_RET_STRING(AE_INSUFFICIENT_DATA_IN_BUFFER)
- CASE_ENUM_RET_STRING(QE_UNEXPECTED_ERROR)
- CASE_ENUM_RET_STRING(QE_PARAMETER_ERROR)
- CASE_ENUM_RET_STRING(QE_EPIDBLOB_ERROR)
- CASE_ENUM_RET_STRING(QE_REVOKED_ERROR)
- CASE_ENUM_RET_STRING(QE_SIGRL_ERROR)
- CASE_ENUM_RET_STRING(PVE_UNEXPECTED_ERROR)
- CASE_ENUM_RET_STRING(PVE_PARAMETER_ERROR)
- CASE_ENUM_RET_STRING(PVE_EPIDBLOB_ERROR)
- CASE_ENUM_RET_STRING(PVE_INSUFFICIENT_MEMORY_ERROR)
- CASE_ENUM_RET_STRING(PVE_INTEGRITY_CHECK_ERROR)
- CASE_ENUM_RET_STRING(PVE_SIGRL_INTEGRITY_CHECK_ERROR)
- CASE_ENUM_RET_STRING(PVE_SERVER_REPORTED_ERROR)
- CASE_ENUM_RET_STRING(PVE_PEK_SIGN_ERROR)
- CASE_ENUM_RET_STRING(PVE_MSG_ERROR)
- CASE_ENUM_RET_STRING(PVE_REVOKED_ERROR)
- CASE_ENUM_RET_STRING(PVE_SESSION_OUT_OF_ORDER_ERROR)
- CASE_ENUM_RET_STRING(PVE_SERVER_BUSY_ERROR)
- CASE_ENUM_RET_STRING(PVE_PERFORMANCE_REKEY_NOT_SUPPORTED)
- CASE_ENUM_RET_STRING(LE_UNEXPECTED_ERROR)
- CASE_ENUM_RET_STRING(LE_INVALID_PARAMETER)
- CASE_ENUM_RET_STRING(LE_GET_EINITTOKEN_KEY_ERROR)
- CASE_ENUM_RET_STRING(LE_INVALID_ATTRIBUTE)
- CASE_ENUM_RET_STRING(LE_INVALID_PRIVILEGE_ERROR)
- CASE_ENUM_RET_STRING(LE_WHITELIST_UNINITIALIZED_ERROR)
- CASE_ENUM_RET_STRING(LE_CALC_LIC_TOKEN_ERROR)
- CASE_ENUM_RET_STRING(AESM_NLTP_NO_LTP_BLOB)
- CASE_ENUM_RET_STRING(AESM_NLTP_DONT_NEED_UPDATE_PAIR_LTP)
- CASE_ENUM_RET_STRING(AESM_NLTP_MAY_NEED_UPDATE_LTP)
- CASE_ENUM_RET_STRING(AESM_NLTP_OLD_EPID11_RLS)
- CASE_ENUM_RET_STRING(AESM_PCP_NEED_PSE_UPDATE)
- CASE_ENUM_RET_STRING(AESM_PCP_PSE_CERT_PROVISIONING_ATTESTATION_FAILURE_NEED_EPID_UPDATE)
- CASE_ENUM_RET_STRING(AESM_PCP_PSE_CERT_PROVISIONING_ATTESTATION_FAILURE_MIGHT_NEED_EPID_UPDATE)
- CASE_ENUM_RET_STRING(AESM_PCP_SIMPLE_PSE_CERT_PROVISIONING_ERROR)
- CASE_ENUM_RET_STRING(AESM_PCP_SIMPLE_EPID_PROVISION_ERROR)
- CASE_ENUM_RET_STRING(AESM_NPC_DONT_NEED_PSEP)
- CASE_ENUM_RET_STRING(AESM_NPC_NO_PSE_CERT)
- CASE_ENUM_RET_STRING(AESM_NPC_DONT_NEED_UPDATE_PSEP)
- CASE_ENUM_RET_STRING(AESM_NPC_MAY_NEED_UPDATE_PSEP)
- CASE_ENUM_RET_STRING(AESM_NEP_DONT_NEED_EPID_PROVISIONING)
- CASE_ENUM_RET_STRING(AESM_NEP_DONT_NEED_UPDATE_PVEQE)
- CASE_ENUM_RET_STRING(AESM_NEP_PERFORMANCE_REKEY)
- CASE_ENUM_RET_STRING(AESM_NEP_MAY_NEED_UPDATE)
- CASE_ENUM_RET_STRING(AESM_CP_ATTESTATION_FAILURE)
- CASE_ENUM_RET_STRING(AESM_LTP_PSE_CERT_REVOKED)
- CASE_ENUM_RET_STRING(AESM_LTP_SIMPLE_LTP_ERROR)
- CASE_ENUM_RET_STRING(AESM_PSE_PR_GET_PRIVRL_ERROR)
- CASE_ENUM_RET_STRING(AESM_NETWORK_TIMEOUT)
- CASE_ENUM_RET_STRING(PSW_UPDATE_REQUIRED)
- CASE_ENUM_RET_STRING(PSE_OP_ERROR_KDF_MISMATCH)
- CASE_ENUM_RET_STRING(AESM_AE_OUT_OF_EPC)
- CASE_ENUM_RET_STRING(PVE_PROV_ATTEST_KEY_NOT_FOUND)
- CASE_ENUM_RET_STRING(PVE_INVALID_REPORT)
- CASE_ENUM_RET_STRING(PVE_XEGDSK_SIGN_ERROR)
- // PCE ERROR CODES
- CASE_ENUM_RET_STRING(PCE_UNEXPECTED_ERROR)
- CASE_ENUM_RET_STRING(PCE_INVALID_PRIVILEGE)
- CASE_ENUM_RET_STRING(PCE_INVALID_REPORT)
- CASE_ENUM_RET_STRING(LE_WHITE_LIST_QUERY_BUSY)
- CASE_ENUM_RET_STRING(AESM_AE_NO_DEVICE)
- CASE_ENUM_RET_STRING(EXTENDED_GROUP_NOT_AVAILABLE)
- default:
- return "Unknown ae_error_t";
- }
- }
- //(aesm%d)
- static const char *get_aesm_error_t_string(aesm_error_t aesm_error)
- {
- switch (aesm_error){
- CASE_ENUM_RET_STRING(AESM_SUCCESS)
- CASE_ENUM_RET_STRING(AESM_UNEXPECTED_ERROR)
- CASE_ENUM_RET_STRING(AESM_NO_DEVICE_ERROR)
- CASE_ENUM_RET_STRING(AESM_PARAMETER_ERROR)
- CASE_ENUM_RET_STRING(AESM_EPIDBLOB_ERROR)
- CASE_ENUM_RET_STRING(AESM_EPID_REVOKED_ERROR)
- CASE_ENUM_RET_STRING(AESM_GET_LICENSETOKEN_ERROR)
- CASE_ENUM_RET_STRING(AESM_SESSION_INVALID)
- CASE_ENUM_RET_STRING(AESM_MAX_NUM_SESSION_REACHED)
- CASE_ENUM_RET_STRING(AESM_PSDA_UNAVAILABLE)
- CASE_ENUM_RET_STRING(AESM_KDF_MISMATCH)
- CASE_ENUM_RET_STRING(AESM_EPH_SESSION_FAILED)
- CASE_ENUM_RET_STRING(AESM_LONG_TERM_PAIRING_FAILED)
- CASE_ENUM_RET_STRING(AESM_NETWORK_ERROR)
- CASE_ENUM_RET_STRING(AESM_NETWORK_BUSY_ERROR)
- CASE_ENUM_RET_STRING(AESM_PROXY_SETTING_ASSIST)
- CASE_ENUM_RET_STRING(AESM_FILE_ACCESS_ERROR)
- CASE_ENUM_RET_STRING(AESM_SGX_PROVISION_FAILED)
- CASE_ENUM_RET_STRING(AESM_SERVICE_STOPPED)
- CASE_ENUM_RET_STRING(AESM_BUSY)
- CASE_ENUM_RET_STRING(AESM_BACKEND_SERVER_BUSY)
- CASE_ENUM_RET_STRING(AESM_UPDATE_AVAILABLE)
- CASE_ENUM_RET_STRING(AESM_OUT_OF_MEMORY_ERROR)
- CASE_ENUM_RET_STRING(AESM_MSG_ERROR)
- CASE_ENUM_RET_STRING(AESM_ENABLE_SGX_DEVICE_FAILED)
- CASE_ENUM_RET_STRING(AESM_PLATFORM_INFO_BLOB_INVALID_SIG)
- CASE_ENUM_RET_STRING(AESM_OUT_OF_EPC)
- CASE_ENUM_RET_STRING(AESM_SERVICE_UNAVAILABLE)
- CASE_ENUM_RET_STRING(AESM_UNRECOGNIZED_PLATFORM)
- default:
- return "Unknow aesm_error_t";
- }
- }
- //(sgx)
- static const char *get_sgx_status_t_string(sgx_status_t status)
- {
- switch (status){
- CASE_ENUM_RET_STRING(SGX_SUCCESS)
- CASE_ENUM_RET_STRING(SGX_ERROR_UNEXPECTED)
- CASE_ENUM_RET_STRING(SGX_ERROR_INVALID_PARAMETER)
- CASE_ENUM_RET_STRING(SGX_ERROR_OUT_OF_MEMORY)
- CASE_ENUM_RET_STRING(SGX_ERROR_ENCLAVE_LOST)
- CASE_ENUM_RET_STRING(SGX_ERROR_INVALID_STATE)
- CASE_ENUM_RET_STRING(SGX_ERROR_INVALID_FUNCTION)
- CASE_ENUM_RET_STRING(SGX_ERROR_OUT_OF_TCS)
- CASE_ENUM_RET_STRING(SGX_ERROR_ENCLAVE_CRASHED )
- CASE_ENUM_RET_STRING(SGX_ERROR_ECALL_NOT_ALLOWED)
- CASE_ENUM_RET_STRING(SGX_ERROR_OCALL_NOT_ALLOWED)
- CASE_ENUM_RET_STRING(SGX_ERROR_UNDEFINED_SYMBOL)
- CASE_ENUM_RET_STRING(SGX_ERROR_INVALID_ENCLAVE)
- CASE_ENUM_RET_STRING(SGX_ERROR_INVALID_ENCLAVE_ID)
- CASE_ENUM_RET_STRING(SGX_ERROR_INVALID_SIGNATURE)
- CASE_ENUM_RET_STRING(SGX_ERROR_NDEBUG_ENCLAVE)
- CASE_ENUM_RET_STRING(SGX_ERROR_OUT_OF_EPC)
- CASE_ENUM_RET_STRING(SGX_ERROR_NO_DEVICE)
- CASE_ENUM_RET_STRING(SGX_ERROR_MEMORY_MAP_CONFLICT)
- CASE_ENUM_RET_STRING(SGX_ERROR_INVALID_METADATA)
- CASE_ENUM_RET_STRING(SGX_ERROR_DEVICE_BUSY)
- CASE_ENUM_RET_STRING(SGX_ERROR_INVALID_VERSION)
- CASE_ENUM_RET_STRING(SGX_ERROR_MODE_INCOMPATIBLE)
- CASE_ENUM_RET_STRING(SGX_ERROR_ENCLAVE_FILE_ACCESS)
- CASE_ENUM_RET_STRING(SGX_ERROR_INVALID_MISC)
- CASE_ENUM_RET_STRING(SGX_ERROR_MAC_MISMATCH)
- CASE_ENUM_RET_STRING(SGX_ERROR_INVALID_ATTRIBUTE)
- CASE_ENUM_RET_STRING(SGX_ERROR_INVALID_CPUSVN)
- CASE_ENUM_RET_STRING(SGX_ERROR_INVALID_ISVSVN)
- CASE_ENUM_RET_STRING(SGX_ERROR_INVALID_KEYNAME)
- CASE_ENUM_RET_STRING(SGX_ERROR_SERVICE_UNAVAILABLE)
- CASE_ENUM_RET_STRING(SGX_ERROR_SERVICE_TIMEOUT)
- CASE_ENUM_RET_STRING(SGX_ERROR_AE_INVALID_EPIDBLOB)
- CASE_ENUM_RET_STRING(SGX_ERROR_SERVICE_INVALID_PRIVILEGE)
- CASE_ENUM_RET_STRING(SGX_ERROR_EPID_MEMBER_REVOKED)
- CASE_ENUM_RET_STRING(SGX_ERROR_UPDATE_NEEDED)
- CASE_ENUM_RET_STRING(SGX_ERROR_NETWORK_FAILURE)
- CASE_ENUM_RET_STRING(SGX_ERROR_AE_SESSION_INVALID)
- CASE_ENUM_RET_STRING(SGX_ERROR_BUSY)
- CASE_ENUM_RET_STRING(SGX_ERROR_MC_NOT_FOUND)
- CASE_ENUM_RET_STRING(SGX_ERROR_MC_NO_ACCESS_RIGHT)
- CASE_ENUM_RET_STRING(SGX_ERROR_MC_USED_UP)
- CASE_ENUM_RET_STRING(SGX_ERROR_MC_OVER_QUOTA)
- CASE_ENUM_RET_STRING(SGX_ERROR_KDF_MISMATCH)
- default:
- return "Unknown sgx_status_t";
- }
- }
- #endif
|