AESMLogicWrapper.cpp 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. /*
  2. * Copyright (C) 2011-2018 Intel Corporation. All rights reserved.
  3. *
  4. * Redistribution and use in source and binary forms, with or without
  5. * modification, are permitted provided that the following conditions
  6. * are met:
  7. *
  8. * * Redistributions of source code must retain the above copyright
  9. * notice, this list of conditions and the following disclaimer.
  10. * * Redistributions in binary form must reproduce the above copyright
  11. * notice, this list of conditions and the following disclaimer in
  12. * the documentation and/or other materials provided with the
  13. * distribution.
  14. * * Neither the name of Intel Corporation nor the names of its
  15. * contributors may be used to endorse or promote products derived
  16. * from this software without specific prior written permission.
  17. *
  18. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  19. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  20. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  21. * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  22. * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  23. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  24. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  25. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  26. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  27. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  28. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  29. *
  30. */
  31. #include "AESMLogicWrapper.h"
  32. #include <iostream>
  33. #include <unistd.h>
  34. #include "LEClass.h"
  35. #include "sgx_quote.h"
  36. aesm_error_t AESMLogicWrapper::initQuote(uint8_t** target_info,
  37. uint32_t* target_info_length,
  38. uint8_t** gid,
  39. uint32_t* gid_length)
  40. {
  41. uint8_t *output_target_info = new uint8_t[sizeof(sgx_target_info_t)]();
  42. uint8_t *output_gid = new uint8_t[sizeof(sgx_epid_group_id_t)]();
  43. uint32_t output_target_info_length=sizeof(sgx_target_info_t);
  44. uint32_t output_gid_length=sizeof(sgx_epid_group_id_t);
  45. aesm_error_t result = AESMLogic::init_quote(output_target_info, output_target_info_length,
  46. output_gid, output_gid_length);
  47. if(result == AESM_SUCCESS)
  48. {
  49. *target_info = output_target_info;
  50. *target_info_length = output_target_info_length;
  51. *gid = output_gid;
  52. *gid_length = output_gid_length;
  53. }
  54. else
  55. {
  56. delete [] output_target_info;
  57. delete [] output_gid;
  58. }
  59. return result;
  60. }
  61. aesm_error_t AESMLogicWrapper::getQuote(uint32_t reportLength, const uint8_t* report,
  62. uint32_t quoteType,
  63. uint32_t spidLength, const uint8_t* spid,
  64. uint32_t nonceLength, const uint8_t* nonce,
  65. uint32_t sig_rlLength, const uint8_t* sig_rl,
  66. uint32_t bufferSize, uint8_t** quote,
  67. bool b_qe_report, uint32_t* qe_reportSize, uint8_t** qe_report)
  68. {
  69. uint8_t *output_quote = new uint8_t[bufferSize]();
  70. uint8_t *output_qe_report = NULL;
  71. uint32_t output_qe_reportSize = 0;
  72. if (b_qe_report)
  73. {
  74. output_qe_report = new uint8_t[sizeof(sgx_report_t)]();
  75. output_qe_reportSize = sizeof(sgx_report_t);
  76. }
  77. aesm_error_t result = AESMLogic::get_quote(report, reportLength,
  78. quoteType,
  79. spid, spidLength,
  80. nonce, nonceLength,
  81. sig_rl, sig_rlLength,
  82. output_qe_report, output_qe_reportSize,
  83. output_quote, bufferSize);
  84. if(result == AESM_SUCCESS)
  85. {
  86. *quote = output_quote;
  87. *qe_report = output_qe_report;
  88. *qe_reportSize = output_qe_reportSize;
  89. }
  90. else
  91. {
  92. delete [] output_quote;
  93. if (output_qe_report)
  94. delete [] output_qe_report;
  95. }
  96. return result;
  97. }
  98. aesm_error_t AESMLogicWrapper::closeSession(uint32_t sessionId)
  99. {
  100. return AESMLogic::close_session(sessionId);
  101. }
  102. aesm_error_t AESMLogicWrapper::createSession(uint32_t *session_id,
  103. uint8_t **se_dh_msg1,
  104. uint32_t se_dh_msg1_size)
  105. {
  106. uint8_t *output_se_dh_msg1 = new uint8_t[se_dh_msg1_size]();
  107. aesm_error_t result = AESMLogic::create_session(session_id, output_se_dh_msg1, se_dh_msg1_size);
  108. if(result == AESM_SUCCESS)
  109. {
  110. *se_dh_msg1 = output_se_dh_msg1;
  111. }
  112. else
  113. {
  114. delete [] output_se_dh_msg1;
  115. }
  116. return result;
  117. }
  118. aesm_error_t AESMLogicWrapper::exchangeReport(uint32_t session_id,
  119. const uint8_t* se_dh_msg2,
  120. uint32_t se_dh_msg2_size,
  121. uint8_t** se_dh_msg3,
  122. uint32_t se_dh_msg3_size )
  123. {
  124. uint8_t *output_se_dh_msg3 = new uint8_t[se_dh_msg3_size]();
  125. aesm_error_t result = AESMLogic::exchange_report(session_id,
  126. se_dh_msg2,
  127. se_dh_msg2_size,
  128. output_se_dh_msg3,
  129. se_dh_msg3_size);
  130. if(result == AESM_SUCCESS)
  131. {
  132. *se_dh_msg3 = output_se_dh_msg3;
  133. }
  134. else
  135. {
  136. delete [] output_se_dh_msg3;
  137. }
  138. return result;
  139. }
  140. aesm_error_t AESMLogicWrapper::getLaunchToken(const uint8_t *measurement,
  141. uint32_t measurement_size,
  142. const uint8_t *mrsigner,
  143. uint32_t mrsigner_size,
  144. const uint8_t *se_attributes,
  145. uint32_t se_attributes_size,
  146. uint8_t **launch_token,
  147. uint32_t *launch_token_size)
  148. {
  149. uint32_t output_launch_token_size = sizeof(token_t);
  150. uint8_t *output_launch_token = new uint8_t[sizeof(token_t)]();
  151. aesm_error_t result = AESMLogic::get_launch_token(measurement,
  152. measurement_size,
  153. mrsigner,
  154. mrsigner_size,
  155. se_attributes,
  156. se_attributes_size,
  157. output_launch_token,
  158. output_launch_token_size);
  159. if(result == AESM_SUCCESS)
  160. {
  161. *launch_token = output_launch_token;
  162. *launch_token_size = output_launch_token_size;
  163. }
  164. else
  165. {
  166. delete [] output_launch_token;
  167. }
  168. return result;
  169. }
  170. aesm_error_t AESMLogicWrapper::invokeService(const uint8_t *pse_message_req,
  171. uint32_t pse_message_req_size,
  172. uint8_t **pse_message_resp,
  173. uint32_t pse_message_resp_size)
  174. {
  175. uint8_t* output_pse_message_resp = new uint8_t[pse_message_resp_size]();
  176. aesm_error_t result = AESMLogic::invoke_service(pse_message_req,
  177. pse_message_req_size,
  178. output_pse_message_resp,
  179. pse_message_resp_size);
  180. if (result == AESM_SUCCESS)
  181. {
  182. *pse_message_resp = output_pse_message_resp;
  183. }
  184. else
  185. {
  186. delete[] output_pse_message_resp;
  187. }
  188. return result;
  189. }
  190. aesm_error_t AESMLogicWrapper::getPsCap(uint64_t* ps_cap)
  191. {
  192. return AESMLogic::get_ps_cap(ps_cap);
  193. }
  194. aesm_error_t AESMLogicWrapper::reportAttestationStatus(uint8_t* platform_info, uint32_t platform_info_size,
  195. uint32_t attestation_error_code,
  196. uint8_t** update_info, uint32_t update_info_size)
  197. {
  198. uint8_t* output_update_info = new uint8_t[update_info_size]();
  199. aesm_error_t result = AESMLogic::report_attestation_status(platform_info,platform_info_size,
  200. attestation_error_code,
  201. output_update_info, update_info_size);
  202. //update_info is valid when result is AESM_UPDATE_AVAILABLE
  203. if (result == AESM_SUCCESS || result == AESM_UPDATE_AVAILABLE)
  204. {
  205. *update_info = output_update_info;
  206. }
  207. else
  208. {
  209. delete[] output_update_info;
  210. }
  211. return result;
  212. }
  213. aesm_error_t AESMLogicWrapper::getWhiteListSize(uint32_t* white_list_size)
  214. {
  215. return AESMLogic::get_white_list_size(white_list_size);
  216. }
  217. aesm_error_t AESMLogicWrapper::getWhiteList(uint8_t **white_list,
  218. uint32_t white_list_size)
  219. {
  220. uint8_t* output_white_list = new uint8_t[white_list_size]();
  221. aesm_error_t result = AESMLogic::get_white_list(output_white_list, white_list_size);
  222. if (result == AESM_SUCCESS)
  223. {
  224. *white_list = output_white_list;
  225. }
  226. else
  227. {
  228. delete[] output_white_list;
  229. }
  230. return result;
  231. }
  232. aesm_error_t AESMLogicWrapper::sgxGetExtendedEpidGroupId(uint32_t* x_group_id)
  233. {
  234. return AESMLogic::get_extended_epid_group_id(x_group_id);
  235. }
  236. aesm_error_t AESMLogicWrapper::sgxSwitchExtendedEpidGroup(uint32_t x_group_id)
  237. {
  238. return AESMLogic::switch_extended_epid_group(x_group_id);
  239. }
  240. aesm_error_t AESMLogicWrapper::sgxRegister(uint8_t* buf, uint32_t buf_size, uint32_t data_type)
  241. {
  242. if(data_type == SGX_REGISTER_WHITE_LIST_CERT){
  243. return AESMLogic::white_list_register(buf, buf_size);
  244. }else{
  245. return AESM_PARAMETER_ERROR;
  246. }
  247. }
  248. void AESMLogicWrapper::service_stop()
  249. {
  250. AESMLogic::service_stop();
  251. }