group__ifapi__policy__callbacks.html 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
  5. <meta http-equiv="X-UA-Compatible" content="IE=9"/>
  6. <meta name="generator" content="Doxygen 1.8.13"/>
  7. <meta name="viewport" content="width=device-width, initial-scale=1"/>
  8. <title>tpm2-tss: Policy callback functions.</title>
  9. <link href="tabs.css" rel="stylesheet" type="text/css"/>
  10. <script type="text/javascript" src="jquery.js"></script>
  11. <script type="text/javascript" src="dynsections.js"></script>
  12. <link href="navtree.css" rel="stylesheet" type="text/css"/>
  13. <script type="text/javascript" src="resize.js"></script>
  14. <script type="text/javascript" src="navtreedata.js"></script>
  15. <script type="text/javascript" src="navtree.js"></script>
  16. <script type="text/javascript">
  17. $(document).ready(initResizable);
  18. </script>
  19. <link href="doxygen.css" rel="stylesheet" type="text/css" />
  20. </head>
  21. <body>
  22. <div id="top"><!-- do not remove this div, it is closed by doxygen! -->
  23. <div id="titlearea">
  24. <table cellspacing="0" cellpadding="0">
  25. <tbody>
  26. <tr style="height: 56px;">
  27. <td id="projectalign" style="padding-left: 0.5em;">
  28. <div id="projectname">tpm2-tss
  29. &#160;<span id="projectnumber">3.2.0</span>
  30. </div>
  31. <div id="projectbrief">TPM Software stack 2.0 TCG spec compliant implementation</div>
  32. </td>
  33. </tr>
  34. </tbody>
  35. </table>
  36. </div>
  37. <!-- end header part -->
  38. <!-- Generated by Doxygen 1.8.13 -->
  39. <script type="text/javascript" src="menudata.js"></script>
  40. <script type="text/javascript" src="menu.js"></script>
  41. <script type="text/javascript">
  42. $(function() {
  43. initMenu('',false,false,'search.php','Search');
  44. });
  45. </script>
  46. <div id="main-nav"></div>
  47. </div><!-- top -->
  48. <div id="side-nav" class="ui-resizable side-nav-resizable">
  49. <div id="nav-tree">
  50. <div id="nav-tree-contents">
  51. <div id="nav-sync" class="sync"></div>
  52. </div>
  53. </div>
  54. <div id="splitbar" style="-moz-user-select:none;"
  55. class="ui-resizable-handle">
  56. </div>
  57. </div>
  58. <script type="text/javascript">
  59. $(document).ready(function(){initNavTree('group__ifapi__policy__callbacks.html','');});
  60. </script>
  61. <div id="doc-content">
  62. <div class="header">
  63. <div class="summary">
  64. <a href="#func-members">Functions</a> </div>
  65. <div class="headertitle">
  66. <div class="title">Policy callback functions.<div class="ingroups"><a class="el" href="group__fapi.html">Feature API</a> &raquo; <a class="el" href="group__ifapi.html">Internals of Feature API</a></div></div> </div>
  67. </div><!--header-->
  68. <div class="contents">
  69. <table class="memberdecls">
  70. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="func-members"></a>
  71. Functions</h2></td></tr>
  72. <tr class="memitem:gac886bf2a0cd070979c90bc4423e3d343"><td class="memItemLeft" align="right" valign="top">TSS2_RC&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ifapi__policy__callbacks.html#gac886bf2a0cd070979c90bc4423e3d343">ifapi_branch_selection</a> (<a class="el" href="struct_t_p_m_l___p_o_l_i_c_y_b_r_a_n_c_h_e_s.html">TPML_POLICYBRANCHES</a> *branches, size_t *branch_idx, void *userdata)</td></tr>
  73. <tr class="separator:gac886bf2a0cd070979c90bc4423e3d343"><td class="memSeparator" colspan="2">&#160;</td></tr>
  74. <tr class="memitem:ga10715ee791f9a8a37c071cafa85dc7e1"><td class="memItemLeft" align="right" valign="top">TSS2_RC&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ifapi__policy__callbacks.html#ga10715ee791f9a8a37c071cafa85dc7e1">ifapi_exec_auth_nv_policy</a> (TPM2B_NV_PUBLIC *nv_public, TPMI_ALG_HASH hash_alg, void *userdata)</td></tr>
  75. <tr class="separator:ga10715ee791f9a8a37c071cafa85dc7e1"><td class="memSeparator" colspan="2">&#160;</td></tr>
  76. <tr class="memitem:gaf778195543972a79fc9ab0b6756e97ef"><td class="memItemLeft" align="right" valign="top">TSS2_RC&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ifapi__policy__callbacks.html#gaf778195543972a79fc9ab0b6756e97ef">ifapi_get_duplicate_name</a> (TPM2B_NAME *name, void *userdata)</td></tr>
  77. <tr class="separator:gaf778195543972a79fc9ab0b6756e97ef"><td class="memSeparator" colspan="2">&#160;</td></tr>
  78. <tr class="memitem:ga297e58a7ce5c56556862ec819e2dafd4"><td class="memItemLeft" align="right" valign="top">TSS2_RC&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ifapi__policy__callbacks.html#ga297e58a7ce5c56556862ec819e2dafd4">ifapi_get_key_public</a> (const char *path, TPMT_PUBLIC *public, void *ctx)</td></tr>
  79. <tr class="separator:ga297e58a7ce5c56556862ec819e2dafd4"><td class="memSeparator" colspan="2">&#160;</td></tr>
  80. <tr class="memitem:gadb0fadb64aeee337839ba64cca0ffd78"><td class="memItemLeft" align="right" valign="top">TSS2_RC&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ifapi__policy__callbacks.html#gadb0fadb64aeee337839ba64cca0ffd78">ifapi_get_nv_public</a> (const char *path, TPM2B_NV_PUBLIC *nv_public, void *ctx)</td></tr>
  81. <tr class="separator:gadb0fadb64aeee337839ba64cca0ffd78"><td class="memSeparator" colspan="2">&#160;</td></tr>
  82. <tr class="memitem:ga7b6fe64874f104dd78e2bf52daa552ab"><td class="memItemLeft" align="right" valign="top">TSS2_RC&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ifapi__policy__callbacks.html#ga7b6fe64874f104dd78e2bf52daa552ab">ifapi_get_object_name</a> (const char *path, TPM2B_NAME *name, void *ctx)</td></tr>
  83. <tr class="separator:ga7b6fe64874f104dd78e2bf52daa552ab"><td class="memSeparator" colspan="2">&#160;</td></tr>
  84. <tr class="memitem:gadd7eb66246e0cf577e7483d982327b8e"><td class="memItemLeft" align="right" valign="top">TSS2_RC&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ifapi__policy__callbacks.html#gadd7eb66246e0cf577e7483d982327b8e">ifapi_policy_action</a> (const char *action, void *userdata)</td></tr>
  85. <tr class="separator:gadd7eb66246e0cf577e7483d982327b8e"><td class="memSeparator" colspan="2">&#160;</td></tr>
  86. <tr class="memitem:ga0b46c66ee5f543af5eecca6373c2a6e4"><td class="memItemLeft" align="right" valign="top">TSS2_RC&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ifapi__policy__callbacks.html#ga0b46c66ee5f543af5eecca6373c2a6e4">ifapi_policyeval_cbauth</a> (TPM2B_NAME *name, <a class="el" href="group___e_s_y_s___t_r.html#ga65d10db3b0b31fcd709e692f1545d30f">ESYS_TR</a> *object_handle, <a class="el" href="group___e_s_y_s___t_r.html#ga65d10db3b0b31fcd709e692f1545d30f">ESYS_TR</a> *auth_handle, <a class="el" href="group___e_s_y_s___t_r.html#ga65d10db3b0b31fcd709e692f1545d30f">ESYS_TR</a> *authSession, void *userdata)</td></tr>
  87. <tr class="separator:ga0b46c66ee5f543af5eecca6373c2a6e4"><td class="memSeparator" colspan="2">&#160;</td></tr>
  88. <tr class="memitem:gaf73e9ba8195cf4e4a0133d66f18009da"><td class="memItemLeft" align="right" valign="top">TSS2_RC&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__ifapi__policy__callbacks.html#gaf73e9ba8195cf4e4a0133d66f18009da">ifapi_read_pcr</a> (TPMS_PCR_SELECT *pcr_select, TPML_PCR_SELECTION *pcr_selection, <a class="el" href="struct_t_p_m_l___p_c_r_v_a_l_u_e_s.html">TPML_PCRVALUES</a> **pcr_values, void *ctx)</td></tr>
  89. <tr class="separator:gaf73e9ba8195cf4e4a0133d66f18009da"><td class="memSeparator" colspan="2">&#160;</td></tr>
  90. </table>
  91. <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
  92. <p>Provides internal callbacks functions for policy execution. </p>
  93. <h2 class="groupheader">Function Documentation</h2>
  94. <a id="gac886bf2a0cd070979c90bc4423e3d343"></a>
  95. <h2 class="memtitle"><span class="permalink"><a href="#gac886bf2a0cd070979c90bc4423e3d343">&#9670;&nbsp;</a></span>ifapi_branch_selection()</h2>
  96. <div class="memitem">
  97. <div class="memproto">
  98. <table class="memname">
  99. <tr>
  100. <td class="memname">TSS2_RC ifapi_branch_selection </td>
  101. <td>(</td>
  102. <td class="paramtype"><a class="el" href="struct_t_p_m_l___p_o_l_i_c_y_b_r_a_n_c_h_e_s.html">TPML_POLICYBRANCHES</a> *&#160;</td>
  103. <td class="paramname"><em>branches</em>, </td>
  104. </tr>
  105. <tr>
  106. <td class="paramkey"></td>
  107. <td></td>
  108. <td class="paramtype">size_t *&#160;</td>
  109. <td class="paramname"><em>branch_idx</em>, </td>
  110. </tr>
  111. <tr>
  112. <td class="paramkey"></td>
  113. <td></td>
  114. <td class="paramtype">void *&#160;</td>
  115. <td class="paramname"><em>userdata</em>&#160;</td>
  116. </tr>
  117. <tr>
  118. <td></td>
  119. <td>)</td>
  120. <td></td><td></td>
  121. </tr>
  122. </table>
  123. </div><div class="memdoc">
  124. <p>Callback for branch selection of policy or.</p>
  125. <dl class="params"><dt>Parameters</dt><dd>
  126. <table class="params">
  127. <tr><td class="paramdir">[in]</td><td class="paramname">branches</td><td>The list of policy branches. </td></tr>
  128. <tr><td class="paramdir">[out]</td><td class="paramname">branch_idx</td><td>The index of the selcted branch. </td></tr>
  129. <tr><td class="paramdir">[in,out]</td><td class="paramname">userdata</td><td>The Fapi context which will be used for keystore access, and storing the policy execution state. the io state. </td></tr>
  130. </table>
  131. </dd>
  132. </dl>
  133. <dl class="retval"><dt>Return values</dt><dd>
  134. <table class="retval">
  135. <tr><td class="paramname">TSS2_RC_SUCCESS</td><td>on success. </td></tr>
  136. <tr><td class="paramname">TSS2_FAPI_RC_BAD_REFERENCE</td><td>if context is NULL. </td></tr>
  137. <tr><td class="paramname">TSS2_FAPI_RC_AUTHORIZATION_UNKNOWN</td><td>if no branch selection callback is defined. This callback will be needed of or policies which have to be executed. </td></tr>
  138. <tr><td class="paramname">TSS2_FAPI_RC_AUTHORIZATION_FAILED</td><td>if the computed branch index delivered by the callback does not identify a branch. </td></tr>
  139. </table>
  140. </dd>
  141. </dl>
  142. </div>
  143. </div>
  144. <a id="ga10715ee791f9a8a37c071cafa85dc7e1"></a>
  145. <h2 class="memtitle"><span class="permalink"><a href="#ga10715ee791f9a8a37c071cafa85dc7e1">&#9670;&nbsp;</a></span>ifapi_exec_auth_nv_policy()</h2>
  146. <div class="memitem">
  147. <div class="memproto">
  148. <table class="memname">
  149. <tr>
  150. <td class="memname">TSS2_RC ifapi_exec_auth_nv_policy </td>
  151. <td>(</td>
  152. <td class="paramtype">TPM2B_NV_PUBLIC *&#160;</td>
  153. <td class="paramname"><em>nv_public</em>, </td>
  154. </tr>
  155. <tr>
  156. <td class="paramkey"></td>
  157. <td></td>
  158. <td class="paramtype">TPMI_ALG_HASH&#160;</td>
  159. <td class="paramname"><em>hash_alg</em>, </td>
  160. </tr>
  161. <tr>
  162. <td class="paramkey"></td>
  163. <td></td>
  164. <td class="paramtype">void *&#160;</td>
  165. <td class="paramname"><em>userdata</em>&#160;</td>
  166. </tr>
  167. <tr>
  168. <td></td>
  169. <td>)</td>
  170. <td></td><td></td>
  171. </tr>
  172. </table>
  173. </div><div class="memdoc">
  174. <p>Callback for executing a policy identified by a digest stored in a nv object.</p>
  175. <dl class="params"><dt>Parameters</dt><dd>
  176. <table class="params">
  177. <tr><td class="paramdir">[in]</td><td class="paramname">nv_public</td><td>the public data of the nv object which stores the digest of the authorized policy. </td></tr>
  178. <tr><td class="paramdir">[in]</td><td class="paramname">hash_alg</td><td>The hash algorithm used for policy computation. </td></tr>
  179. <tr><td class="paramdir">[in]</td><td class="paramname">userdata</td><td>The user context to retrieve the policy. </td></tr>
  180. </table>
  181. </dd>
  182. </dl>
  183. <dl class="retval"><dt>Return values</dt><dd>
  184. <table class="retval">
  185. <tr><td class="paramname">TSS2_RC_SUCCESS</td><td>on success. </td></tr>
  186. <tr><td class="paramname">TSS2_FAPI_RC_MEMORY</td><td>if it's not possible to allocate enough memory. </td></tr>
  187. <tr><td class="paramname">TSS2_FAPI_RC_BAD_REFERENCE</td><td>If no user data id passed or context stack is not initialized. </td></tr>
  188. <tr><td class="paramname">TSS2_FAPI_RC_IO_ERROR</td><td>If an error occurs during access to the policy store. </td></tr>
  189. <tr><td class="paramname">TSS2_FAPI_RC_PATH_NOT_FOUND</td><td>If a policy for a certain path was not found. </td></tr>
  190. <tr><td class="paramname">TSS2_FAPI_RC_POLICY_UNKNOWN</td><td>If policy search for a certain policy digest was not successful. </td></tr>
  191. <tr><td class="paramname">TPM2_RC_BAD_AUTH</td><td>If the authentication for an object needed for policy execution fails. </td></tr>
  192. <tr><td class="paramname">TSS2_FAPI_RC_BAD_VALUE</td><td>if an invalid value was passed into the function. </td></tr>
  193. <tr><td class="paramname">TSS2_FAPI_RC_TRY_AGAIN</td><td>if an I/O operation is not finished yet and this function needs to be called again. </td></tr>
  194. <tr><td class="paramname">TSS2_FAPI_RC_BAD_SEQUENCE</td><td>if the context has an asynchronous operation already pending. </td></tr>
  195. <tr><td class="paramname">TSS2_FAPI_RC_KEY_NOT_FOUND</td><td>if a key was not found. </td></tr>
  196. <tr><td class="paramname">TSS2_FAPI_RC_GENERAL_FAILURE</td><td>if an internal error occurred. </td></tr>
  197. <tr><td class="paramname">TSS2_FAPI_RC_AUTHORIZATION_UNKNOWN</td><td>if a required authorization callback is not set. </td></tr>
  198. <tr><td class="paramname">TSS2_FAPI_RC_AUTHORIZATION_FAILED</td><td>if the authorization attempt fails. </td></tr>
  199. <tr><td class="paramname">TSS2_ESYS_RC_*</td><td>possible error codes of ESAPI. </td></tr>
  200. <tr><td class="paramname">TSS2_FAPI_RC_BAD_PATH</td><td>if the path is used in inappropriate context or contains illegal characters. </td></tr>
  201. <tr><td class="paramname">TSS2_FAPI_RC_NOT_PROVISIONED</td><td>FAPI was not provisioned. </td></tr>
  202. </table>
  203. </dd>
  204. </dl>
  205. </div>
  206. </div>
  207. <a id="gaf778195543972a79fc9ab0b6756e97ef"></a>
  208. <h2 class="memtitle"><span class="permalink"><a href="#gaf778195543972a79fc9ab0b6756e97ef">&#9670;&nbsp;</a></span>ifapi_get_duplicate_name()</h2>
  209. <div class="memitem">
  210. <div class="memproto">
  211. <table class="memname">
  212. <tr>
  213. <td class="memname">TSS2_RC ifapi_get_duplicate_name </td>
  214. <td>(</td>
  215. <td class="paramtype">TPM2B_NAME *&#160;</td>
  216. <td class="paramname"><em>name</em>, </td>
  217. </tr>
  218. <tr>
  219. <td class="paramkey"></td>
  220. <td></td>
  221. <td class="paramtype">void *&#160;</td>
  222. <td class="paramname"><em>userdata</em>&#160;</td>
  223. </tr>
  224. <tr>
  225. <td></td>
  226. <td>)</td>
  227. <td></td><td></td>
  228. </tr>
  229. </table>
  230. </div><div class="memdoc">
  231. <p>Callback for getting the name of a key to be duplicated.</p>
  232. <dl class="params"><dt>Parameters</dt><dd>
  233. <table class="params">
  234. <tr><td class="paramdir">[out]</td><td class="paramname">name</td><td>the name of the object to be duplicated. </td></tr>
  235. <tr><td class="paramdir">[in]</td><td class="paramname">userdata</td><td>The user context to retrieve the key. </td></tr>
  236. </table>
  237. </dd>
  238. </dl>
  239. <dl class="retval"><dt>Return values</dt><dd>
  240. <table class="retval">
  241. <tr><td class="paramname">TSS2_RC_SUCCESS</td><td>on success. </td></tr>
  242. <tr><td class="paramname">TSS2_FAPI_RC_BAD_REFERENCE</td><td>if the context is not passed or the object to be duplicated is not set. </td></tr>
  243. </table>
  244. </dd>
  245. </dl>
  246. </div>
  247. </div>
  248. <a id="ga297e58a7ce5c56556862ec819e2dafd4"></a>
  249. <h2 class="memtitle"><span class="permalink"><a href="#ga297e58a7ce5c56556862ec819e2dafd4">&#9670;&nbsp;</a></span>ifapi_get_key_public()</h2>
  250. <div class="memitem">
  251. <div class="memproto">
  252. <table class="memname">
  253. <tr>
  254. <td class="memname">TSS2_RC ifapi_get_key_public </td>
  255. <td>(</td>
  256. <td class="paramtype">const char *&#160;</td>
  257. <td class="paramname"><em>path</em>, </td>
  258. </tr>
  259. <tr>
  260. <td class="paramkey"></td>
  261. <td></td>
  262. <td class="paramtype">TPMT_PUBLIC *&#160;</td>
  263. <td class="paramname"><em>public</em>, </td>
  264. </tr>
  265. <tr>
  266. <td class="paramkey"></td>
  267. <td></td>
  268. <td class="paramtype">void *&#160;</td>
  269. <td class="paramname"><em>ctx</em>&#160;</td>
  270. </tr>
  271. <tr>
  272. <td></td>
  273. <td>)</td>
  274. <td></td><td></td>
  275. </tr>
  276. </table>
  277. </div><div class="memdoc">
  278. <p>Get public data of a key from keystore.</p>
  279. <dl class="params"><dt>Parameters</dt><dd>
  280. <table class="params">
  281. <tr><td class="paramdir">[in]</td><td class="paramname">path</td><td>The relative path of the key. </td></tr>
  282. <tr><td class="paramdir">[out]</td><td class="paramname">public</td><td>The caller allocated public structure. </td></tr>
  283. <tr><td class="paramdir">[in,out]</td><td class="paramname">ctx</td><td>The context to access io and keystore module and to store the io state. </td></tr>
  284. </table>
  285. </dd>
  286. </dl>
  287. <dl class="retval"><dt>Return values</dt><dd>
  288. <table class="retval">
  289. <tr><td class="paramname">TSS2_RC_SUCCESS</td><td>on success. </td></tr>
  290. <tr><td class="paramname">TSS2_FAPI_RC_IO_ERROR</td><td>if the data cannot be loaded. </td></tr>
  291. <tr><td class="paramname">TSS2_FAPI_RC_MEMORY</td><td>if the FAPI cannot allocate enough memory for internal operations or return parameters. </td></tr>
  292. <tr><td class="paramname">TSS2_FAPI_RC_BAD_TEMPLATE</td><td>If the loaded template is not appropriate for this operation. </td></tr>
  293. <tr><td class="paramname">TSS2_FAPI_RC_BAD_VALUE</td><td>if an invalid value was passed into the function. </td></tr>
  294. <tr><td class="paramname">TSS2_FAPI_RC_TRY_AGAIN</td><td>if an I/O operation is not finished yet and this function needs to be called again. </td></tr>
  295. <tr><td class="paramname">TSS2_FAPI_RC_BAD_SEQUENCE</td><td>if the context has an asynchronous operation already pending. </td></tr>
  296. <tr><td class="paramname">TSS2_FAPI_RC_PATH_NOT_FOUND</td><td>if a FAPI object path was not found during authorization. </td></tr>
  297. <tr><td class="paramname">TSS2_FAPI_RC_KEY_NOT_FOUND</td><td>if a key was not found. </td></tr>
  298. <tr><td class="paramname">TSS2_FAPI_RC_GENERAL_FAILURE</td><td>if an internal error occurred. </td></tr>
  299. <tr><td class="paramname">TSS2_FAPI_RC_BAD_REFERENCE</td><td>a invalid null pointer is passed. </td></tr>
  300. <tr><td class="paramname">TSS2_FAPI_RC_NOT_PROVISIONED</td><td>FAPI was not provisioned. </td></tr>
  301. <tr><td class="paramname">TSS2_FAPI_RC_BAD_PATH</td><td>if the path is used in inappropriate context or contains illegal characters. </td></tr>
  302. </table>
  303. </dd>
  304. </dl>
  305. </div>
  306. </div>
  307. <a id="gadb0fadb64aeee337839ba64cca0ffd78"></a>
  308. <h2 class="memtitle"><span class="permalink"><a href="#gadb0fadb64aeee337839ba64cca0ffd78">&#9670;&nbsp;</a></span>ifapi_get_nv_public()</h2>
  309. <div class="memitem">
  310. <div class="memproto">
  311. <table class="memname">
  312. <tr>
  313. <td class="memname">TSS2_RC ifapi_get_nv_public </td>
  314. <td>(</td>
  315. <td class="paramtype">const char *&#160;</td>
  316. <td class="paramname"><em>path</em>, </td>
  317. </tr>
  318. <tr>
  319. <td class="paramkey"></td>
  320. <td></td>
  321. <td class="paramtype">TPM2B_NV_PUBLIC *&#160;</td>
  322. <td class="paramname"><em>nv_public</em>, </td>
  323. </tr>
  324. <tr>
  325. <td class="paramkey"></td>
  326. <td></td>
  327. <td class="paramtype">void *&#160;</td>
  328. <td class="paramname"><em>ctx</em>&#160;</td>
  329. </tr>
  330. <tr>
  331. <td></td>
  332. <td>)</td>
  333. <td></td><td></td>
  334. </tr>
  335. </table>
  336. </div><div class="memdoc">
  337. <p>Get public data of a NV object from keystore.</p>
  338. <dl class="params"><dt>Parameters</dt><dd>
  339. <table class="params">
  340. <tr><td class="paramdir">[in]</td><td class="paramname">path</td><td>The relative path of the NV object. </td></tr>
  341. <tr><td class="paramdir">[out]</td><td class="paramname">nv_public</td><td>The caller allocated public structure. </td></tr>
  342. <tr><td class="paramdir">[in,out]</td><td class="paramname">ctx</td><td>The context to access io and keystore module and to store the io state. </td></tr>
  343. </table>
  344. </dd>
  345. </dl>
  346. <dl class="retval"><dt>Return values</dt><dd>
  347. <table class="retval">
  348. <tr><td class="paramname">TSS2_RC_SUCCESS</td><td>on success. </td></tr>
  349. <tr><td class="paramname">TSS2_FAPI_RC_IO_ERROR</td><td>if the data cannot be loaded. </td></tr>
  350. <tr><td class="paramname">TSS2_FAPI_RC_MEMORY</td><td>if the FAPI cannot allocate enough memory for internal operations or return parameters. </td></tr>
  351. <tr><td class="paramname">TSS2_FAPI_RC_BAD_TEMPLATE</td><td>If the loaded template is not appropriate for this operation. </td></tr>
  352. <tr><td class="paramname">TSS2_FAPI_RC_BAD_VALUE</td><td>if an invalid value was passed into the function. </td></tr>
  353. <tr><td class="paramname">TSS2_FAPI_RC_TRY_AGAIN</td><td>if an I/O operation is not finished yet and this function needs to be called again. </td></tr>
  354. <tr><td class="paramname">TSS2_FAPI_RC_BAD_SEQUENCE</td><td>if the context has an asynchronous operation already pending. </td></tr>
  355. <tr><td class="paramname">TSS2_FAPI_RC_PATH_NOT_FOUND</td><td>if a FAPI object path was not found during authorization. </td></tr>
  356. <tr><td class="paramname">TSS2_FAPI_RC_KEY_NOT_FOUND</td><td>if a key was not found. </td></tr>
  357. <tr><td class="paramname">TSS2_FAPI_RC_GENERAL_FAILURE</td><td>if an internal error occurred. </td></tr>
  358. <tr><td class="paramname">TSS2_FAPI_RC_BAD_REFERENCE</td><td>a invalid null pointer is passed. </td></tr>
  359. <tr><td class="paramname">TSS2_FAPI_RC_NOT_PROVISIONED</td><td>FAPI was not provisioned. </td></tr>
  360. <tr><td class="paramname">TSS2_FAPI_RC_BAD_PATH</td><td>if the path is used in inappropriate context or contains illegal characters. </td></tr>
  361. </table>
  362. </dd>
  363. </dl>
  364. </div>
  365. </div>
  366. <a id="ga7b6fe64874f104dd78e2bf52daa552ab"></a>
  367. <h2 class="memtitle"><span class="permalink"><a href="#ga7b6fe64874f104dd78e2bf52daa552ab">&#9670;&nbsp;</a></span>ifapi_get_object_name()</h2>
  368. <div class="memitem">
  369. <div class="memproto">
  370. <table class="memname">
  371. <tr>
  372. <td class="memname">TSS2_RC ifapi_get_object_name </td>
  373. <td>(</td>
  374. <td class="paramtype">const char *&#160;</td>
  375. <td class="paramname"><em>path</em>, </td>
  376. </tr>
  377. <tr>
  378. <td class="paramkey"></td>
  379. <td></td>
  380. <td class="paramtype">TPM2B_NAME *&#160;</td>
  381. <td class="paramname"><em>name</em>, </td>
  382. </tr>
  383. <tr>
  384. <td class="paramkey"></td>
  385. <td></td>
  386. <td class="paramtype">void *&#160;</td>
  387. <td class="paramname"><em>ctx</em>&#160;</td>
  388. </tr>
  389. <tr>
  390. <td></td>
  391. <td>)</td>
  392. <td></td><td></td>
  393. </tr>
  394. </table>
  395. </div><div class="memdoc">
  396. <p>Get TPM name of an object from key keystore.</p>
  397. <dl class="params"><dt>Parameters</dt><dd>
  398. <table class="params">
  399. <tr><td class="paramdir">[in]</td><td class="paramname">path</td><td>The relative path of the object. </td></tr>
  400. <tr><td class="paramdir">[out]</td><td class="paramname">name</td><td>The caller allocate public structure. </td></tr>
  401. <tr><td class="paramdir">[in,out]</td><td class="paramname">ctx</td><td>The context to access io and keystore module and to store the io state. </td></tr>
  402. </table>
  403. </dd>
  404. </dl>
  405. <dl class="retval"><dt>Return values</dt><dd>
  406. <table class="retval">
  407. <tr><td class="paramname">TSS2_RC_SUCCESS</td><td>on success. </td></tr>
  408. <tr><td class="paramname">TSS2_FAPI_RC_IO_ERROR</td><td>if the data cannot be loaded. </td></tr>
  409. <tr><td class="paramname">TSS2_FAPI_RC_MEMORY</td><td>if the FAPI cannot allocate enough memory for internal operations or return parameters. </td></tr>
  410. <tr><td class="paramname">TSS2_FAPI_RC_BAD_TEMPLATE</td><td>If the loaded template is not appropriate for this operation. </td></tr>
  411. <tr><td class="paramname">TSS2_FAPI_RC_BAD_VALUE</td><td>if an invalid value was passed into the function. </td></tr>
  412. <tr><td class="paramname">TSS2_FAPI_RC_TRY_AGAIN</td><td>if an I/O operation is not finished yet and this function needs to be called again. </td></tr>
  413. <tr><td class="paramname">TSS2_FAPI_RC_BAD_SEQUENCE</td><td>if the context has an asynchronous operation already pending. </td></tr>
  414. <tr><td class="paramname">TSS2_FAPI_RC_PATH_NOT_FOUND</td><td>if a FAPI object path was not found during authorization. </td></tr>
  415. <tr><td class="paramname">TSS2_FAPI_RC_KEY_NOT_FOUND</td><td>if a key was not found. </td></tr>
  416. <tr><td class="paramname">TSS2_FAPI_RC_GENERAL_FAILURE</td><td>if an internal error occurred. </td></tr>
  417. <tr><td class="paramname">TSS2_FAPI_RC_BAD_REFERENCE</td><td>a invalid null pointer is passed. </td></tr>
  418. <tr><td class="paramname">TSS2_FAPI_RC_NOT_PROVISIONED</td><td>FAPI was not provisioned. </td></tr>
  419. <tr><td class="paramname">TSS2_FAPI_RC_BAD_PATH</td><td>if the path is used in inappropriate context or contains illegal characters. </td></tr>
  420. </table>
  421. </dd>
  422. </dl>
  423. </div>
  424. </div>
  425. <a id="gadd7eb66246e0cf577e7483d982327b8e"></a>
  426. <h2 class="memtitle"><span class="permalink"><a href="#gadd7eb66246e0cf577e7483d982327b8e">&#9670;&nbsp;</a></span>ifapi_policy_action()</h2>
  427. <div class="memitem">
  428. <div class="memproto">
  429. <table class="memname">
  430. <tr>
  431. <td class="memname">TSS2_RC ifapi_policy_action </td>
  432. <td>(</td>
  433. <td class="paramtype">const char *&#160;</td>
  434. <td class="paramname"><em>action</em>, </td>
  435. </tr>
  436. <tr>
  437. <td class="paramkey"></td>
  438. <td></td>
  439. <td class="paramtype">void *&#160;</td>
  440. <td class="paramname"><em>userdata</em>&#160;</td>
  441. </tr>
  442. <tr>
  443. <td></td>
  444. <td>)</td>
  445. <td></td><td></td>
  446. </tr>
  447. </table>
  448. </div><div class="memdoc">
  449. <p>Callback for policy action.</p>
  450. <dl class="params"><dt>Parameters</dt><dd>
  451. <table class="params">
  452. <tr><td class="paramdir">[in]</td><td class="paramname">action</td><td>The name of the policy action. </td></tr>
  453. <tr><td class="paramdir">[in,out]</td><td class="paramname">userdata</td><td>The Fapi context which will be used for keystore access, and storing the policy execution state. the io state. </td></tr>
  454. </table>
  455. </dd>
  456. </dl>
  457. <dl class="retval"><dt>Return values</dt><dd>
  458. <table class="retval">
  459. <tr><td class="paramname">TSS2_RC_SUCCESS</td><td>on success. </td></tr>
  460. <tr><td class="paramname">TSS2_FAPI_RC_AUTHORIZATION_UNKNOWN</td><td>If the callback for branch selection is not defined. This callback will be needed of or policies have to be executed. </td></tr>
  461. <tr><td class="paramname">TSS2_FAPI_RC_BAD_REFERENCE</td><td>If no user data is passed. </td></tr>
  462. </table>
  463. </dd>
  464. </dl>
  465. </div>
  466. </div>
  467. <a id="ga0b46c66ee5f543af5eecca6373c2a6e4"></a>
  468. <h2 class="memtitle"><span class="permalink"><a href="#ga0b46c66ee5f543af5eecca6373c2a6e4">&#9670;&nbsp;</a></span>ifapi_policyeval_cbauth()</h2>
  469. <div class="memitem">
  470. <div class="memproto">
  471. <table class="memname">
  472. <tr>
  473. <td class="memname">TSS2_RC ifapi_policyeval_cbauth </td>
  474. <td>(</td>
  475. <td class="paramtype">TPM2B_NAME *&#160;</td>
  476. <td class="paramname"><em>name</em>, </td>
  477. </tr>
  478. <tr>
  479. <td class="paramkey"></td>
  480. <td></td>
  481. <td class="paramtype"><a class="el" href="group___e_s_y_s___t_r.html#ga65d10db3b0b31fcd709e692f1545d30f">ESYS_TR</a> *&#160;</td>
  482. <td class="paramname"><em>object_handle</em>, </td>
  483. </tr>
  484. <tr>
  485. <td class="paramkey"></td>
  486. <td></td>
  487. <td class="paramtype"><a class="el" href="group___e_s_y_s___t_r.html#ga65d10db3b0b31fcd709e692f1545d30f">ESYS_TR</a> *&#160;</td>
  488. <td class="paramname"><em>auth_handle</em>, </td>
  489. </tr>
  490. <tr>
  491. <td class="paramkey"></td>
  492. <td></td>
  493. <td class="paramtype"><a class="el" href="group___e_s_y_s___t_r.html#ga65d10db3b0b31fcd709e692f1545d30f">ESYS_TR</a> *&#160;</td>
  494. <td class="paramname"><em>authSession</em>, </td>
  495. </tr>
  496. <tr>
  497. <td class="paramkey"></td>
  498. <td></td>
  499. <td class="paramtype">void *&#160;</td>
  500. <td class="paramname"><em>userdata</em>&#160;</td>
  501. </tr>
  502. <tr>
  503. <td></td>
  504. <td>)</td>
  505. <td></td><td></td>
  506. </tr>
  507. </table>
  508. </div><div class="memdoc">
  509. <p>Callback for authorization of objects used by policy.</p>
  510. <dl class="params"><dt>Parameters</dt><dd>
  511. <table class="params">
  512. <tr><td class="paramdir">[in]</td><td class="paramname">name</td><td>The name of the object to be authorized. </td></tr>
  513. <tr><td class="paramdir">[in]</td><td class="paramname">object_handle</td><td>The ESYS handle of the used object. </td></tr>
  514. <tr><td class="paramdir">[in]</td><td class="paramname">auth_handle</td><td>will be used for object authorization. For keys it will we equal to the object handle. </td></tr>
  515. <tr><td class="paramdir">[out]</td><td class="paramname">authSession</td><td>The session used for object authorization. </td></tr>
  516. <tr><td class="paramdir">[in,out]</td><td class="paramname">userdata</td><td>The Fapi context which will be used for keystore access, and storing the policy execution state. the io state. </td></tr>
  517. </table>
  518. </dd>
  519. </dl>
  520. <dl class="retval"><dt>Return values</dt><dd>
  521. <table class="retval">
  522. <tr><td class="paramname">TSS2_RC_SUCCESS</td><td>on success. </td></tr>
  523. <tr><td class="paramname">TSS2_FAPI_RC_BAD_REFERENCE</td><td>if context or policy is NULL. </td></tr>
  524. <tr><td class="paramname">TSS2_FAPI_RC_MEMORY</td><td>if memory allocation failed. </td></tr>
  525. <tr><td class="paramname">TSS2_FAPI_RC_TRY_AGAIN</td><td>if the asynchronous operation is not yet complete. Call this function again later. </td></tr>
  526. <tr><td class="paramname">TSS2_FAPI_RC_BAD_SEQUENCE</td><td>if the context has an asynchronous operation already pending. </td></tr>
  527. <tr><td class="paramname">TSS2_FAPI_RC_PATH_NOT_FOUND</td><td>If a policy was not found. </td></tr>
  528. <tr><td class="paramname">TSS2_FAPI_RC_KEY_NOT_FOUND</td><td>If a key was not found. </td></tr>
  529. <tr><td class="paramname">TSS2_FAPI_RC_IO_ERROR</td><td>If an IO error occurred during reading a policy or a key. </td></tr>
  530. <tr><td class="paramname">TSS2_FAPI_RC_GENERAL_FAILURE</td><td>If an error in an used library occurred. </td></tr>
  531. <tr><td class="paramname">TSS2_FAPI_RC_BAD_VALUE</td><td>if an invalid value was passed into the function. </td></tr>
  532. <tr><td class="paramname">TSS2_FAPI_RC_AUTHORIZATION_UNKNOWN</td><td>if a required authorization callback is not set. </td></tr>
  533. <tr><td class="paramname">TSS2_FAPI_RC_AUTHORIZATION_FAILED</td><td>if the authorization attempt fails. </td></tr>
  534. <tr><td class="paramname">TSS2_FAPI_RC_POLICY_UNKNOWN</td><td>if policy search for a certain policy digest was not successful. </td></tr>
  535. <tr><td class="paramname">TSS2_ESYS_RC_*</td><td>possible error codes of ESAPI. </td></tr>
  536. <tr><td class="paramname">TSS2_FAPI_RC_BAD_PATH</td><td>if the path is used in inappropriate context or contains illegal characters. </td></tr>
  537. <tr><td class="paramname">TSS2_FAPI_RC_NOT_PROVISIONED</td><td>FAPI was not provisioned. </td></tr>
  538. </table>
  539. </dd>
  540. </dl>
  541. </div>
  542. </div>
  543. <a id="gaf73e9ba8195cf4e4a0133d66f18009da"></a>
  544. <h2 class="memtitle"><span class="permalink"><a href="#gaf73e9ba8195cf4e4a0133d66f18009da">&#9670;&nbsp;</a></span>ifapi_read_pcr()</h2>
  545. <div class="memitem">
  546. <div class="memproto">
  547. <table class="memname">
  548. <tr>
  549. <td class="memname">TSS2_RC ifapi_read_pcr </td>
  550. <td>(</td>
  551. <td class="paramtype">TPMS_PCR_SELECT *&#160;</td>
  552. <td class="paramname"><em>pcr_select</em>, </td>
  553. </tr>
  554. <tr>
  555. <td class="paramkey"></td>
  556. <td></td>
  557. <td class="paramtype">TPML_PCR_SELECTION *&#160;</td>
  558. <td class="paramname"><em>pcr_selection</em>, </td>
  559. </tr>
  560. <tr>
  561. <td class="paramkey"></td>
  562. <td></td>
  563. <td class="paramtype"><a class="el" href="struct_t_p_m_l___p_c_r_v_a_l_u_e_s.html">TPML_PCRVALUES</a> **&#160;</td>
  564. <td class="paramname"><em>pcr_values</em>, </td>
  565. </tr>
  566. <tr>
  567. <td class="paramkey"></td>
  568. <td></td>
  569. <td class="paramtype">void *&#160;</td>
  570. <td class="paramname"><em>ctx</em>&#160;</td>
  571. </tr>
  572. <tr>
  573. <td></td>
  574. <td>)</td>
  575. <td></td><td></td>
  576. </tr>
  577. </table>
  578. </div><div class="memdoc">
  579. <p>Read values of PCR registers and clear selection.</p>
  580. <dl class="params"><dt>Parameters</dt><dd>
  581. <table class="params">
  582. <tr><td class="paramdir">[in,out]</td><td class="paramname">pcr_select</td><td>The registers to be read (bank selection from profile). </td></tr>
  583. <tr><td class="paramdir">[in,out]</td><td class="paramname">pcr_selection</td><td>The registers to be read (with bank selection). </td></tr>
  584. <tr><td class="paramdir">[out]</td><td class="paramname">pcr_values</td><td>The callee-allocated public structure. </td></tr>
  585. <tr><td class="paramdir">[in,out]</td><td class="paramname">ctx</td><td>The context to access io and keystore module and to store the io state. </td></tr>
  586. </table>
  587. </dd>
  588. </dl>
  589. <dl class="retval"><dt>Return values</dt><dd>
  590. <table class="retval">
  591. <tr><td class="paramname">TSS2_RC_SUCCESS</td><td>on success. </td></tr>
  592. <tr><td class="paramname">TSS2_FAPI_RC_BAD_VALUE</td><td>if the input parameters had inappropriate values. </td></tr>
  593. <tr><td class="paramname">TSS2_FAPI_RC_TRY_AGAIN</td><td>if the asynchronous operation is not yet complete. Call this function again later. </td></tr>
  594. <tr><td class="paramname">TSS2_FAPI_RC_MEMORY</td><td>if memory allocation failed. </td></tr>
  595. <tr><td class="paramname">TSS2_FAPI_RC_BAD_SEQUENCE</td><td>if the context has an asynchronous operation already pending. </td></tr>
  596. </table>
  597. </dd>
  598. </dl>
  599. </div>
  600. </div>
  601. </div><!-- contents -->
  602. </div><!-- doc-content -->
  603. <!-- start footer part -->
  604. <div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
  605. <ul>
  606. <li class="footer">Generated by
  607. <a href="http://www.doxygen.org/index.html">
  608. <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.13 </li>
  609. </ul>
  610. </div>
  611. </body>
  612. </html>