xref: /netbsd-src/crypto/external/cpl/trousers/dist/src/include/obj_rsakey.h (revision 1023804e3833a0bd94414f2545512128f6502c74)
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