1 2 /* 3 * Licensed Materials - Property of IBM 4 * 5 * trousers - An open source TCG Software Stack 6 * 7 * (C) Copyright International Business Machines Corp. 2004-2007 8 * 9 */ 10 11 #ifndef _OBJ_RSAKEY_H_ 12 #define _OBJ_RSAKEY_H_ 13 14 #ifdef TSS_BUILD_RSAKEY_LIST 15 16 /* rsakey specific flags */ 17 #define TSS_RSAKEY_FLAG_OWNEREVICT (0x00000001) 18 19 /* structures */ 20 struct tr_rsakey_obj { 21 int type; 22 TSS_KEY key; 23 TSS_FLAG flags; 24 TSS_HPOLICY usagePolicy; 25 TSS_HPOLICY migPolicy; 26 TSS_UUID uuid; 27 TCS_KEY_HANDLE tcsHandle; 28 #ifdef TSS_BUILD_CMK 29 TPM_HMAC msaApproval; 30 TPM_DIGEST msaDigest; 31 #endif 32 union { 33 TPM_PCR_INFO info11; 34 TPM_PCR_INFO_LONG infolong; 35 } pcrInfo; 36 UINT32 pcrInfoType; 37 }; 38 39 /* obj_rsakey.c */ 40 void __tspi_rsakey_free(void *data); 41 TSS_BOOL obj_is_rsakey(TSS_HOBJECT); 42 TSS_RESULT obj_rsakey_add(TSS_HCONTEXT, TSS_FLAG, TSS_HOBJECT *); 43 TSS_RESULT obj_rsakey_add_by_key(TSS_HCONTEXT, TSS_UUID *, BYTE *, TSS_FLAG, TSS_HKEY *); 44 TSS_RESULT obj_rsakey_set_policy(TSS_HKEY, TSS_HPOLICY); 45 TSS_RESULT obj_rsakey_remove(TSS_HOBJECT, TSS_HCONTEXT); 46 TSS_RESULT obj_rsakey_get_tsp_context(TSS_HKEY, TSS_HCONTEXT *); 47 TSS_RESULT obj_rsakey_set_pstype(TSS_HKEY, UINT32); 48 TSS_RESULT obj_rsakey_get_pstype(TSS_HKEY, UINT32 *); 49 TSS_RESULT obj_rsakey_get_usage(TSS_HKEY, UINT32 *); 50 TSS_RESULT obj_rsakey_set_usage(TSS_HKEY, UINT32); 51 TSS_RESULT obj_rsakey_set_migratable(TSS_HKEY, UINT32); 52 TSS_RESULT obj_rsakey_set_redirected(TSS_HKEY, UINT32); 53 TSS_RESULT obj_rsakey_set_volatile(TSS_HKEY, UINT32); 54 TSS_RESULT obj_rsakey_get_authdata_usage(TSS_HKEY, UINT32 *); 55 TSS_RESULT obj_rsakey_set_authdata_usage(TSS_HKEY, UINT32); 56 TSS_RESULT obj_rsakey_get_alg(TSS_HKEY, UINT32 *); 57 TSS_RESULT obj_rsakey_set_alg(TSS_HKEY, UINT32); 58 TSS_RESULT obj_rsakey_get_es(TSS_HKEY, UINT32 *); 59 TSS_RESULT obj_rsakey_set_es(TSS_HKEY, UINT32); 60 TSS_RESULT obj_rsakey_get_ss(TSS_HKEY, UINT32 *); 61 TSS_RESULT obj_rsakey_set_ss(TSS_HKEY, UINT32); 62 TSS_RESULT obj_rsakey_set_num_primes(TSS_HKEY, UINT32); 63 TSS_RESULT obj_rsakey_get_num_primes(TSS_HKEY, UINT32 *); 64 TSS_RESULT obj_rsakey_set_flags(TSS_HKEY, UINT32); 65 TSS_RESULT obj_rsakey_get_flags(TSS_HKEY, UINT32 *); 66 TSS_RESULT obj_rsakey_set_size(TSS_HKEY, UINT32); 67 TSS_RESULT obj_rsakey_get_size(TSS_HKEY, UINT32 *); 68 TSS_BOOL obj_rsakey_is_migratable(TSS_HKEY); 69 TSS_BOOL obj_rsakey_is_redirected(TSS_HKEY); 70 TSS_BOOL obj_rsakey_is_volatile(TSS_HKEY); 71 TSS_RESULT obj_rsakey_get_policy(TSS_HKEY, UINT32, TSS_HPOLICY *, TSS_BOOL *); 72 TSS_RESULT obj_rsakey_get_policies(TSS_HKEY, TSS_HPOLICY *, TSS_HPOLICY *, TSS_BOOL *); 73 TSS_RESULT obj_rsakey_get_blob(TSS_HKEY, UINT32 *, BYTE **); 74 TSS_RESULT obj_rsakey_get_priv_blob(TSS_HKEY, UINT32 *, BYTE **); 75 TSS_RESULT obj_rsakey_get_pub_blob(TSS_HKEY, UINT32 *, BYTE **); 76 TSS_RESULT obj_rsakey_get_version(TSS_HKEY, UINT32 *, BYTE **); 77 TSS_RESULT obj_rsakey_get_exponent(TSS_HKEY, UINT32 *, BYTE **); 78 TSS_RESULT obj_rsakey_set_exponent(TSS_HKEY, UINT32, BYTE *); 79 TSS_RESULT obj_rsakey_get_modulus(TSS_HKEY, UINT32 *, BYTE **); 80 TSS_RESULT obj_rsakey_set_modulus(TSS_HKEY, UINT32, BYTE *); 81 TSS_RESULT obj_rsakey_get_uuid(TSS_HKEY, UINT32 *, BYTE **); 82 TSS_RESULT obj_rsakey_get_parent_uuid(TSS_HKEY, TSS_FLAG *, TSS_UUID *); 83 TSS_RESULT obj_rsakey_set_uuids(TSS_HKEY, TSS_FLAG, TSS_UUID *, TSS_FLAG, TSS_UUID *); 84 TSS_RESULT obj_rsakey_set_uuid(TSS_HKEY, TSS_FLAG, TSS_UUID *); 85 TSS_RESULT obj_rsakey_set_tcpakey(TSS_HKEY, UINT32 , BYTE *); 86 TSS_RESULT obj_rsakey_get_pcr_digest(TSS_HKEY, UINT32, TSS_FLAG, UINT32 *, BYTE **); 87 TSS_RESULT obj_rsakey_get_pcr_selection(TSS_HKEY, UINT32, TSS_FLAG, UINT32 *, BYTE **); 88 TSS_RESULT obj_rsakey_get_pcr_locality(TSS_HKEY, TSS_FLAG, UINT32 *); 89 TSS_RESULT obj_rsakey_set_pubkey(TSS_HKEY, UINT32, BYTE *); 90 TSS_RESULT obj_rsakey_set_privkey(TSS_HKEY, UINT32, UINT32, BYTE *); 91 TSS_RESULT obj_rsakey_set_pcr_data(TSS_HKEY, TSS_HPOLICY); 92 TSS_RESULT obj_rsakey_set_key_parms(TSS_HKEY, TCPA_KEY_PARMS *); 93 TSS_RESULT obj_rsakey_get_by_uuid(TSS_UUID *, TSS_HKEY *); 94 TSS_RESULT obj_rsakey_get_by_pub(UINT32, BYTE *, TSS_HKEY *); 95 TSS_RESULT obj_rsakey_get_tcs_handle(TSS_HKEY, TCS_KEY_HANDLE *); 96 TSS_RESULT obj_rsakey_set_tcs_handle(TSS_HKEY, TCS_KEY_HANDLE); 97 void obj_rsakey_remove_policy_refs(TSS_HPOLICY, TSS_HCONTEXT); 98 TSS_RESULT obj_rsakey_get_transport_attribs(TSS_HKEY, TCS_KEY_HANDLE *, TPM_DIGEST *); 99 #ifdef TSS_BUILD_CMK 100 TSS_BOOL obj_rsakey_is_cmk(TSS_HKEY); 101 TSS_RESULT obj_rsakey_set_cmk(TSS_HKEY, UINT32); 102 TSS_RESULT obj_rsakey_set_msa_approval(TSS_HKEY, UINT32, BYTE *); 103 TSS_RESULT obj_rsakey_get_msa_approval(TSS_HKEY, UINT32 *, BYTE **); 104 TSS_RESULT obj_rsakey_set_msa_digest(TSS_HKEY, UINT32, BYTE *); 105 TSS_RESULT obj_rsakey_get_msa_digest(TSS_HKEY, UINT32 *, BYTE **); 106 #endif 107 TSS_RESULT obj_rsakey_get_ownerevict(TSS_HKEY, UINT32 *); 108 TSS_RESULT obj_rsakey_set_ownerevict(TSS_HKEY, TSS_BOOL); 109 TSS_RESULT obj_rsakey_set_srk_pubkey(BYTE *); 110 111 #define RSAKEY_LIST_DECLARE struct obj_list rsakey_list 112 #define RSAKEY_LIST_DECLARE_EXTERN extern struct obj_list rsakey_list 113 #define RSAKEY_LIST_INIT() tspi_list_init(&rsakey_list) 114 #define RSAKEY_LIST_CONNECT(a,b) obj_connectContext_list(&rsakey_list, a, b) 115 #define RSAKEY_LIST_CLOSE(a) obj_list_close(&rsakey_list, &__tspi_rsakey_free, a) 116 117 #else 118 119 #define obj_is_rsakey(a) FALSE 120 121 #define RSAKEY_LIST_DECLARE 122 #define RSAKEY_LIST_DECLARE_EXTERN 123 #define RSAKEY_LIST_INIT() 124 #define RSAKEY_LIST_CONNECT(a,b) 125 #define RSAKEY_LIST_CLOSE(a) 126 127 #endif 128 129 #endif 130