Go to the documentation of this file.
28 #ifndef A5000PLUGNTRUST_H
29 #define A5000PLUGNTRUST_H
35 #include "drv_digital_out.h"
36 #include "drv_digital_in.h"
37 #include "drv_i2c_master.h"
60 #define A5000PLUGNTRUST_NAD_WRITE 0x5A
61 #define A5000PLUGNTRUST_NAD_READ 0xA5
68 #define A5000PLUGNTRUST_PCB_BLOCK_I 0x00
69 #define A5000PLUGNTRUST_PCB_BLOCK_I_NS_ENCODE 0x40
70 #define A5000PLUGNTRUST_PCB_BLOCK_I_M_CHAIN 0x20
77 #define A5000PLUGNTRUST_PCB_BLOCK_R 0x80
78 #define A5000PLUGNTRUST_PCB_BLOCK_R_NR_ENCODE 0x10
79 #define A5000PLUGNTRUST_PCB_BLOCK_R_ERROR_CRC 0x01
80 #define A5000PLUGNTRUST_PCB_BLOCK_R_ERROR_OTHER 0x02
87 #define A5000PLUGNTRUST_PCB_BLOCK_S 0xC0
88 #define A5000PLUGNTRUST_PCB_BLOCK_S_RESYNC_REQ 0x00
89 #define A5000PLUGNTRUST_PCB_BLOCK_S_RESYNC_RSP 0x20
90 #define A5000PLUGNTRUST_PCB_BLOCK_S_IFS_REQ 0x01
91 #define A5000PLUGNTRUST_PCB_BLOCK_S_IFS_RSP 0x21
92 #define A5000PLUGNTRUST_PCB_BLOCK_S_ABORT_REQ 0x02
93 #define A5000PLUGNTRUST_PCB_BLOCK_S_ABORT_RSP 0x22
94 #define A5000PLUGNTRUST_PCB_BLOCK_S_WTX_REQ 0x03
95 #define A5000PLUGNTRUST_PCB_BLOCK_S_WTX_RSP 0x23
96 #define A5000PLUGNTRUST_PCB_BLOCK_S_SOFT_RESET_REQ 0x0F
97 #define A5000PLUGNTRUST_PCB_BLOCK_S_SOFT_RESET_RSP 0x2F
98 #define A5000PLUGNTRUST_PCB_BLOCK_S_END_APDU_SESSION_REQ 0x05
99 #define A5000PLUGNTRUST_PCB_BLOCK_S_END_APDU_SESSION_RSP 0x25
100 #define A5000PLUGNTRUST_PCB_BLOCK_S_SE_RESET_REQ 0x06
101 #define A5000PLUGNTRUST_PCB_BLOCK_S_SE_RESET_RSP 0x26
102 #define A5000PLUGNTRUST_PCB_BLOCK_S_GET_ATR_REQ 0x07
103 #define A5000PLUGNTRUST_PCB_BLOCK_S_GET_ATR_RSP 0x27
121 #define A5000PLUGNTRUST_CLA_SECURE 0x84
122 #define A5000PLUGNTRUST_CLA_NOT_SECURE 0x80
128 #define A5000PLUGNTRUST_INS_MASK_INS_CHAR 0xE0
129 #define A5000PLUGNTRUST_INS_MASK_INSTRUCTION 0x1F
130 #define A5000PLUGNTRUST_INS_TRANSIENT 0x80
131 #define A5000PLUGNTRUST_INS_AUTH_OBJECT 0x40
132 #define A5000PLUGNTRUST_INS_ATTEST 0x20
133 #define A5000PLUGNTRUST_INS_WRITE 0x01
134 #define A5000PLUGNTRUST_INS_READ 0x02
135 #define A5000PLUGNTRUST_INS_CRYPTO 0x03
136 #define A5000PLUGNTRUST_INS_MGMT 0x04
137 #define A5000PLUGNTRUST_INS_PROCESS 0x05
138 #define A5000PLUGNTRUST_INS_IMPORT_EXTERNAL 0x06
144 #define A5000PLUGNTRUST_P1_UNUSED 0x80
145 #define A5000PLUGNTRUST_P1_MASK_KEY_TYPE 0x60
146 #define A5000PLUGNTRUST_P1_MASK_CRED_TYPE 0x1F
147 #define A5000PLUGNTRUST_P1_KEY_PAIR 0x60
148 #define A5000PLUGNTRUST_P1_PRIVATE 0x40
149 #define A5000PLUGNTRUST_P1_PUBLIC 0x20
150 #define A5000PLUGNTRUST_P1_DEFAULT 0x00
151 #define A5000PLUGNTRUST_P1_EC 0x01
152 #define A5000PLUGNTRUST_P1_RSA 0x02
153 #define A5000PLUGNTRUST_P1_AES 0x03
154 #define A5000PLUGNTRUST_P1_DES 0x04
155 #define A5000PLUGNTRUST_P1_HMAC 0x05
156 #define A5000PLUGNTRUST_P1_BINARY 0x06
157 #define A5000PLUGNTRUST_P1_USERID 0x07
158 #define A5000PLUGNTRUST_P1_COUNTER 0x08
159 #define A5000PLUGNTRUST_P1_PCR 0x09
160 #define A5000PLUGNTRUST_P1_CURVE 0x0B
161 #define A5000PLUGNTRUST_P1_SIGNATURE 0x0C
162 #define A5000PLUGNTRUST_P1_MAC 0x0D
163 #define A5000PLUGNTRUST_P1_CIPHER 0x0E
164 #define A5000PLUGNTRUST_P1_TLS 0x0F
165 #define A5000PLUGNTRUST_P1_CRYPTO_OBJ 0x10
166 #define A5000PLUGNTRUST_P2_DEFAULT 0x00
167 #define A5000PLUGNTRUST_P2_GENERATE 0x03
168 #define A5000PLUGNTRUST_P2_CREATE 0x04
169 #define A5000PLUGNTRUST_P2_SIZE 0x07
170 #define A5000PLUGNTRUST_P2_SIGN 0x09
171 #define A5000PLUGNTRUST_P2_VERIFY 0x0A
172 #define A5000PLUGNTRUST_P2_INIT 0x0B
173 #define A5000PLUGNTRUST_P2_UPDATE 0x0C
174 #define A5000PLUGNTRUST_P2_FINAL 0x0D
175 #define A5000PLUGNTRUST_P2_ONESHOT 0x0E
176 #define A5000PLUGNTRUST_P2_DH 0x0F
177 #define A5000PLUGNTRUST_P2_DIVERSIFY 0x10
178 #define A5000PLUGNTRUST_P2_AUTH_FIRST_PART2 0x12
179 #define A5000PLUGNTRUST_P2_AUTH_NONFIRST_PART2 0x13
180 #define A5000PLUGNTRUST_P2_DUMP_KEY 0x14
181 #define A5000PLUGNTRUST_P2_CHANGE_KEY_PART1 0x15
182 #define A5000PLUGNTRUST_P2_CHANGE_KEY_PART2 0x16
183 #define A5000PLUGNTRUST_P2_KILL_AUTH 0x17
184 #define A5000PLUGNTRUST_P2_IMPORT 0x18
185 #define A5000PLUGNTRUST_P2_EXPORT 0x19
186 #define A5000PLUGNTRUST_P2_SESSION_CREATE 0x1B
187 #define A5000PLUGNTRUST_P2_SESSION_CLOSE 0x1C
188 #define A5000PLUGNTRUST_P2_SESSION_REFRESH 0x1E
189 #define A5000PLUGNTRUST_P2_SESSION_POLICY 0x1F
190 #define A5000PLUGNTRUST_P2_VERSION 0x20
191 #define A5000PLUGNTRUST_P2_MEMORY 0x22
192 #define A5000PLUGNTRUST_P2_LIST 0x25
193 #define A5000PLUGNTRUST_P2_TYPE 0x26
194 #define A5000PLUGNTRUST_P2_EXIST 0x27
195 #define A5000PLUGNTRUST_P2_DELETE_OBJECT 0x28
196 #define A5000PLUGNTRUST_P2_DELETE_ALL 0x2A
197 #define A5000PLUGNTRUST_P2_SESSION_USERID 0x2C
198 #define A5000PLUGNTRUST_P2_HKDF 0x2D
199 #define A5000PLUGNTRUST_P2_PBKDF 0x2E
200 #define A5000PLUGNTRUST_P2_I2CM 0x30
201 #define A5000PLUGNTRUST_P2_I2CM_ATTESTED 0x31
202 #define A5000PLUGNTRUST_P2_MAC 0x32
203 #define A5000PLUGNTRUST_P2_UNLOCK_CHALLENGE 0x33
204 #define A5000PLUGNTRUST_P2_CURVE_LIST 0x34
205 #define A5000PLUGNTRUST_P2_SIGN_ECDAA 0x35
206 #define A5000PLUGNTRUST_P2_ID 0x36
207 #define A5000PLUGNTRUST_P2_ENCRYPT_ONESHOT 0x37
208 #define A5000PLUGNTRUST_P2_DECRYPT_ONESHOT 0x38
209 #define A5000PLUGNTRUST_P2_ATTEST 0x3A
210 #define A5000PLUGNTRUST_P2_ATTRIBUTES 0x3B
211 #define A5000PLUGNTRUST_P2_CPLC 0x3C
212 #define A5000PLUGNTRUST_P2_TIME 0x3D
213 #define A5000PLUGNTRUST_P2_TRANSPORT 0x3E
214 #define A5000PLUGNTRUST_P2_VARIANT 0x3F
215 #define A5000PLUGNTRUST_P2_PARAM 0x40
216 #define A5000PLUGNTRUST_P2_DELETE_CURVE 0x41
217 #define A5000PLUGNTRUST_P2_ENCRYPT 0x42
218 #define A5000PLUGNTRUST_P2_DECRYPT 0x43
219 #define A5000PLUGNTRUST_P2_VALIDATE 0x44
220 #define A5000PLUGNTRUST_P2_GENERATE_ONESHOT 0x45
221 #define A5000PLUGNTRUST_P2_VALIDATE_ONESHOT 0x46
222 #define A5000PLUGNTRUST_P2_CRYPTO_LIST 0x47
223 #define A5000PLUGNTRUST_P2_RANDOM 0x49
224 #define A5000PLUGNTRUST_P2_TLS_PMS 0x4A
225 #define A5000PLUGNTRUST_P2_TLS_PRF_CLI_HELLO 0x4B
226 #define A5000PLUGNTRUST_P2_TLS_PRF_SRV_HELLO 0x4C
227 #define A5000PLUGNTRUST_P2_TLS_PRF_CLI_RND 0x4D
228 #define A5000PLUGNTRUST_P2_TLS_PRF_SRV_RND 0x4E
229 #define A5000PLUGNTRUST_P2_RAW 0x4F
230 #define A5000PLUGNTRUST_P2_IMPORT_EXT 0x51
231 #define A5000PLUGNTRUST_P2_SCP 0x52
232 #define A5000PLUGNTRUST_P2_AUTH_FIRST_PART1 0x53
233 #define A5000PLUGNTRUST_P2_AUTH_NONFIRST_PART1 0x54
239 #define A5000PLUGNTRUST_SECURE_OBJECT_TYPE_EC_KEY_PAIR 0x01
240 #define A5000PLUGNTRUST_SECURE_OBJECT_TYPE_EC_PRIV_KEY 0x02
241 #define A5000PLUGNTRUST_SECURE_OBJECT_TYPE_EC_PUB_KEY 0x03
242 #define A5000PLUGNTRUST_SECURE_OBJECT_TYPE_RSA_KEY_PAIR 0x04
243 #define A5000PLUGNTRUST_SECURE_OBJECT_TYPE_RSA_KEY_PAIR_CRT 0x05
244 #define A5000PLUGNTRUST_SECURE_OBJECT_TYPE_RSA_PRIV_KEY 0x06
245 #define A5000PLUGNTRUST_SECURE_OBJECT_TYPE_RSA_PRIV_KEY_CRT 0x07
246 #define A5000PLUGNTRUST_SECURE_OBJECT_TYPE_RSA_PUB_KEY 0x08
247 #define A5000PLUGNTRUST_SECURE_OBJECT_TYPE_AES_KEY 0x09
248 #define A5000PLUGNTRUST_SECURE_OBJECT_TYPE_DES_KEY 0x0A
249 #define A5000PLUGNTRUST_SECURE_OBJECT_TYPE_BINARY_FILE 0x0B
250 #define A5000PLUGNTRUST_SECURE_OBJECT_TYPE_USERID 0x0C
251 #define A5000PLUGNTRUST_SECURE_OBJECT_TYPE_COUNTER 0x0D
252 #define A5000PLUGNTRUST_SECURE_OBJECT_TYPE_PCR 0x0F
253 #define A5000PLUGNTRUST_SECURE_OBJECT_TYPE_CURVE 0x10
254 #define A5000PLUGNTRUST_SECURE_OBJECT_TYPE_HMAC_KEY 0x11
260 #define A5000PLUGNTRUST_MEM_PERSISTENT 0x01
261 #define A5000PLUGNTRUST_MEM_TRANSIENT_RESET 0x02
262 #define A5000PLUGNTRUST_MEM_TRANSIENT_DESELECT 0x03
268 #define A5000PLUGNTRUST_ORIGIN_EXTERNAL 0x01
269 #define A5000PLUGNTRUST_ORIGIN_INTERNAL 0x02
270 #define A5000PLUGNTRUST_ORIGIN_PROVISIONED 0x03
276 #define A5000PLUGNTRUST_TLV_TAG_SESSION_ID 0x10
277 #define A5000PLUGNTRUST_TLV_TAG_POLICY 0x11
278 #define A5000PLUGNTRUST_TLV_TAG_MAX_ATTEMPTS 0x12
279 #define A5000PLUGNTRUST_TLV_TAG_IMPORT_AUTH_DATA 0x13
280 #define A5000PLUGNTRUST_TLV_TAG_IMPORT_AUTH_KEY_ID 0x14
281 #define A5000PLUGNTRUST_TLV_TAG_1 0x41
282 #define A5000PLUGNTRUST_TLV_TAG_2 0x42
283 #define A5000PLUGNTRUST_TLV_TAG_3 0x43
284 #define A5000PLUGNTRUST_TLV_TAG_4 0x44
285 #define A5000PLUGNTRUST_TLV_TAG_5 0x45
286 #define A5000PLUGNTRUST_TLV_TAG_6 0x46
287 #define A5000PLUGNTRUST_TLV_TAG_7 0x47
288 #define A5000PLUGNTRUST_TLV_TAG_8 0x48
289 #define A5000PLUGNTRUST_TLV_TAG_9 0x49
290 #define A5000PLUGNTRUST_TLV_TAG_10 0x4A
296 #define A5000PLUGNTRUST_ECS_SIG_ECDSA_PLAIN 0x09
297 #define A5000PLUGNTRUST_ECS_SIG_ECDSA_SHA 0x11
298 #define A5000PLUGNTRUST_ECS_SIG_ECDSA_SHA_224 0x25
299 #define A5000PLUGNTRUST_ECS_SIG_ECDSA_SHA_256 0x21
300 #define A5000PLUGNTRUST_ECS_SIG_ECDSA_SHA_384 0x22
301 #define A5000PLUGNTRUST_ECS_SIG_ECDSA_SHA_512 0x26
302 #define A5000PLUGNTRUST_ECS_SIG_ED25519PH_SHA_512 0xA3
303 #define A5000PLUGNTRUST_ECS_SIG_ECDAA 0xF4
309 #define A5000PLUGNTRUST_RSA_SHA1_PKCS1_PSS 0x15
310 #define A5000PLUGNTRUST_RSA_SHA224_PKCS1_PSS 0x2B
311 #define A5000PLUGNTRUST_RSA_SHA256_PKCS1_PSS 0x2C
312 #define A5000PLUGNTRUST_RSA_SHA384_PKCS1_PSS 0x2D
313 #define A5000PLUGNTRUST_RSA_SHA512_PKCS1_PSS 0x2E
314 #define A5000PLUGNTRUST_RSA_SHA1_PKCS1 0x0A
315 #define A5000PLUGNTRUST_RSA_SHA_224_PKCS1 0x27
316 #define A5000PLUGNTRUST_RSA_SHA_256_PKCS1 0x28
317 #define A5000PLUGNTRUST_RSA_SHA_384_PKCS1 0x29
318 #define A5000PLUGNTRUST_RSA_SHA_512_PKCS1 0x2A
319 #define A5000PLUGNTRUST_RSA_NO_PAD 0x0C
320 #define A5000PLUGNTRUST_RSA_PKCS1 0x0A
321 #define A5000PLUGNTRUST_RSA_PKCS1_OAEP 0x0F
322 #define A5000PLUGNTRUST_RSA_512 512
323 #define A5000PLUGNTRUST_RSA_1024 1024
324 #define A5000PLUGNTRUST_RSA_1152 1152
325 #define A5000PLUGNTRUST_RSA_2048 2048
326 #define A5000PLUGNTRUST_RSA_3072 3072
327 #define A5000PLUGNTRUST_RSA_4096 4096
328 #define A5000PLUGNTRUST_RSA_COMP_MOD 0x00
329 #define A5000PLUGNTRUST_RSA_COMP_PUB_EXP 0x01
330 #define A5000PLUGNTRUST_RSA_COMP_PRIV_EXP 0x02
331 #define A5000PLUGNTRUST_RSA_COMP_P 0x03
332 #define A5000PLUGNTRUST_RSA_COMP_Q 0x04
333 #define A5000PLUGNTRUST_RSA_COMP_DP 0x05
334 #define A5000PLUGNTRUST_RSA_COMP_DQ 0x06
335 #define A5000PLUGNTRUST_RSA_COMP_INVQ 0x07
341 #define A5000PLUGNTRUST_DIGEST_NO_HASH 0x00
342 #define A5000PLUGNTRUST_DIGEST_SHA 0x01
343 #define A5000PLUGNTRUST_DIGEST_SHA224 0x07
344 #define A5000PLUGNTRUST_DIGEST_SHA256 0x04
345 #define A5000PLUGNTRUST_DIGEST_SHA384 0x05
346 #define A5000PLUGNTRUST_DIGEST_SHA512 0x06
352 #define A5000PLUGNTRUST_HMAC_SHA1 0x18
353 #define A5000PLUGNTRUST_HMAC_SHA256 0x19
354 #define A5000PLUGNTRUST_HMAC_SHA384 0x1A
355 #define A5000PLUGNTRUST_HMAC_SHA512 0x1B
356 #define A5000PLUGNTRUST_CMAC_128 0x31
362 #define A5000PLUGNTRUST_ECC_UNUSED 0x00
363 #define A5000PLUGNTRUST_ECC_NIST_P192 0x01
364 #define A5000PLUGNTRUST_ECC_NIST_P224 0x02
365 #define A5000PLUGNTRUST_ECC_NIST_P256 0x03
366 #define A5000PLUGNTRUST_ECC_NIST_P384 0x04
367 #define A5000PLUGNTRUST_ECC_NIST_P521 0x05
368 #define A5000PLUGNTRUST_ECC_Brainpool160 0x06
369 #define A5000PLUGNTRUST_ECC_Brainpool192 0x07
370 #define A5000PLUGNTRUST_ECC_Brainpool224 0x08
371 #define A5000PLUGNTRUST_ECC_Brainpool256 0x09
372 #define A5000PLUGNTRUST_ECC_Brainpool320 0x0A
373 #define A5000PLUGNTRUST_ECC_Brainpool384 0x0B
374 #define A5000PLUGNTRUST_ECC_Brainpool512 0x0C
375 #define A5000PLUGNTRUST_ECC_Secp160k1 0x0D
376 #define A5000PLUGNTRUST_ECC_Secp192k1 0x0E
377 #define A5000PLUGNTRUST_ECC_Secp224k1 0x0F
378 #define A5000PLUGNTRUST_ECC_Secp256k1 0x10
379 #define A5000PLUGNTRUST_ECC_TPM_ECC_BN_P256 0x11
380 #define A5000PLUGNTRUST_ECC_ID_ECC_ED_25519 0x40
381 #define A5000PLUGNTRUST_ECC_ID_ECC_MONT_DH_25519 0x41
382 #define A5000PLUGNTRUST_ECC_CURVE_PARAM_A 0x01
383 #define A5000PLUGNTRUST_ECC_CURVE_PARAM_B 0x02
384 #define A5000PLUGNTRUST_ECC_CURVE_PARAM_G 0x04
385 #define A5000PLUGNTRUST_ECC_CURVE_PARAM_N 0x08
386 #define A5000PLUGNTRUST_ECC_CURVE_PARAM_PRIME 0x10
392 #define A5000PLUGNTRUST_CIPHER_DES_CBC_NOPAD 0x01
393 #define A5000PLUGNTRUST_CIPHER_DES_CBC_ISO9797_M1 0x02
394 #define A5000PLUGNTRUST_CIPHER_DES_CBC_ISO9797_M2 0x03
395 #define A5000PLUGNTRUST_CIPHER_DES_CBC_PKCS5 0x04
396 #define A5000PLUGNTRUST_CIPHER_DES_ECB_NOPAD 0x05
397 #define A5000PLUGNTRUST_CIPHER_DES_ECB_ISO9797_M1 0x06
398 #define A5000PLUGNTRUST_CIPHER_DES_ECB_ISO9797_M2 0x07
399 #define A5000PLUGNTRUST_CIPHER_DES_ECB_PKCS5 0x08
400 #define A5000PLUGNTRUST_CIPHER_AES_ECB_NOPAD 0x0E
401 #define A5000PLUGNTRUST_CIPHER_AES_CBC_NOPAD 0x0D
402 #define A5000PLUGNTRUST_CIPHER_AES_CBC_ISO9797_M1 0x16
403 #define A5000PLUGNTRUST_CIPHER_AES_CBC_ISO9797_M2 0x17
404 #define A5000PLUGNTRUST_CIPHER_AES_CBC_PKCS5 0x18
405 #define A5000PLUGNTRUST_CIPHER_AES_CTR 0xF0
411 #define A5000PLUGNTRUST_CONFIG_ECDAA 0x0001
412 #define A5000PLUGNTRUST_CONFIG_ECDSA_ECDH_ECDHE 0x0002
413 #define A5000PLUGNTRUST_CONFIG_EDDSA 0x0004
414 #define A5000PLUGNTRUST_CONFIG_DH_MONT 0x0008
415 #define A5000PLUGNTRUST_CONFIG_HMAC 0x0010
416 #define A5000PLUGNTRUST_CONFIG_RSA_PLAIN 0x0020
417 #define A5000PLUGNTRUST_CONFIG_RSA_CRT 0x0040
418 #define A5000PLUGNTRUST_CONFIG_AES 0x0080
419 #define A5000PLUGNTRUST_CONFIG_DES 0x0100
420 #define A5000PLUGNTRUST_CONFIG_PBKDF 0x0200
421 #define A5000PLUGNTRUST_CONFIG_TLS 0x0400
422 #define A5000PLUGNTRUST_CONFIG_MIFARE 0x0800
423 #define A5000PLUGNTRUST_CONFIG_FIPS_MODE_DISABLED 0x1000
424 #define A5000PLUGNTRUST_CONFIG_I2CM 0x2000
425 #define A5000PLUGNTRUST_CONFIG_ECC_ALL 0x000F
426 #define A5000PLUGNTRUST_CONFIG_RSA_ALL 0x0060
427 #define A5000PLUGNTRUST_CONFIG_ALL 0x3FFF
433 #define A5000PLUGNTRUST_TRANSIENT_LOCK 0x01
434 #define A5000PLUGNTRUST_PERSISTENT_LOCK 0x02
440 #define A5000PLUGNTRUST_LOCKED 0x01
446 #define A5000PLUGNTRUST_CC_DIGEST 0x01
447 #define A5000PLUGNTRUST_CC_CIPHER 0x02
448 #define A5000PLUGNTRUST_CC_SIGNATURE 0x03
454 #define A5000PLUGNTRUST_RESULT_SUCCESS 0x01
455 #define A5000PLUGNTRUST_RESULT_FAILURE 0x02
461 #define A5000PLUGNTRUST_PERSISTENT 0x01
462 #define A5000PLUGNTRUST_TRANSIENT 0x02
468 #define A5000PLUGNTRUST_NOT_SET 0x01
469 #define A5000PLUGNTRUST_SET 0x02
475 #define A5000PLUGNTRUST_NO_MORE 0x01
476 #define A5000PLUGNTRUST_MORE 0x02
482 #define A5000PLUGNTRUST_SCP_REQUIRED 0x01
483 #define A5000PLUGNTRUST_SCP_NOT_REQUIRED 0x02
489 #define A5000PLUGNTRUST_APPLET_RES_ID_TRANSPORT 0x7FFF0200ul
490 #define A5000PLUGNTRUST_APPLET_RES_ID_KP_FASTSCP_USER 0x7FFF0201ul
491 #define A5000PLUGNTRUST_APPLET_RES_ID_KP_FASTSCP_IMPORT 0x7FFF0202ul
492 #define A5000PLUGNTRUST_APPLET_RES_ID_PUB_FASTSCP_IMPORT 0x7FFF0203ul
493 #define A5000PLUGNTRUST_APPLET_RES_ID_FEATURE 0x7FFF0204ul
494 #define A5000PLUGNTRUST_APPLET_RES_ID_FACTORY_RESET 0x7FFF0205ul
495 #define A5000PLUGNTRUST_APPLET_RES_ID_UNIQUE_ID 0x7FFF0206ul
496 #define A5000PLUGNTRUST_APPLET_RES_ID_PLATFORM_SCP 0x7FFF0207ul
502 #define A5000PLUGNTRUST_SW_NOERROR 0x9000
503 #define A5000PLUGNTRUST_SW_CONDITIONS_NOT_SATISFIED 0x6985
504 #define A5000PLUGNTRUST_SW_SECURITY_STATUS 0x6982
505 #define A5000PLUGNTRUST_SW_WRONG_DATA 0x6A80
506 #define A5000PLUGNTRUST_SW_DATA_INVALID 0x6984
507 #define A5000PLUGNTRUST_SW_COMMAND_NOT_ALLOWED 0x6986
513 #define A5000PLUGNTRUST_OBJECT_DOES_EXISTS 1
514 #define A5000PLUGNTRUST_OBJECT_DOESNT_EXIST 2
520 #define A5000PLUGNTRUST_OBJID_SE05X_APPLET_RES_START 0x7FFF0000ul
521 #define A5000PLUGNTRUST_SSS_OBJID_DEMO_AUTH_START 0x7DA00000ul
522 #define A5000PLUGNTRUST_SSS_OBJID_IOT_HUB_A_START 0xF0000000ul
528 #define A5000PLUGNTRUST_OBJID_APPLET_MASK 0xFFFF0000ul
529 #define A5000PLUGNTRUST_OBJID_IOT_MASK 0xF0000000ul
548 #define A5000PLUGNTRUST_CARD_MANAGER_WITH_RSP 1
549 #define A5000PLUGNTRUST_CARD_MANAGER_WITHOUT_RSP 0
556 #define A5000PLUGNTRUST_DEVICE_ADDRESS 0x48
574 #define A5000PLUGNTRUST_MAP_MIKROBUS( cfg, mikrobus ) \
575 cfg.scl = MIKROBUS( mikrobus, MIKROBUS_SCL ); \
576 cfg.sda = MIKROBUS( mikrobus, MIKROBUS_SDA ); \
577 cfg.en = MIKROBUS( mikrobus, MIKROBUS_CS );
626 uint8_t payload[ 0xFF ];
653 uint8_t vendor_id[ 5 ];
656 uint8_t data_link_layer_parameters[ 0x04 ];
661 uint8_t physical_layer_parameters[ 0x0B ];
664 uint8_t historical[ 0x0A ];
959 uint8_t tag, uint8_t *rsp, uint32_t *rsp_len );
1040 uint8_t *cardmanager_rsp, uint8_t *cardmanager_rsp_len );
1129 uint16_t read_len, uint8_t *data_buf, uint32_t *data_len );
1150 uint16_t data_len, uint8_t *data_buf );
1172 #endif // A5000PLUGNTRUST_H
uint8_t len
Definition: a5000plugntrust.h:640
uint8_t protocol_version
Definition: a5000plugntrust.h:652
err_t a5000plugntrust_object_id_list(a5000plugntrust_t *ctx, uint32_t *id_list, uint8_t *list_len)
Reads all Object ID's from Applet.
err_t a5000plugntrust_set_tlv_u8buf_optional(uint8_t *buf, uint8_t *buf_len, uint8_t tag, uint8_t *cmd, uint32_t cmd_len)
Add TLV data buffer in payload buffer if TLV data buffer length greater then 0.
void a5000plugntrust_set_tlv_u32(uint8_t *buf, uint8_t *buf_len, uint8_t tag, uint32_t value)
Add TLV data of 4 bytes value in payload buffer.
@ A5000PLUGNTRUST_OK
Definition: a5000plugntrust.h:689
uint16_t crc16
Definition: a5000plugntrust.h:642
err_t a5000plugntrust_read_object(a5000plugntrust_t *ctx, uint32_t object_id, uint16_t offset, uint16_t read_len, uint8_t *data_buf, uint32_t *data_len)
Read object data.
Version info data.
Definition: a5000plugntrust.h:673
err_t a5000plugntrust_apdu_read(a5000plugntrust_t *ctx, a5000plugntrust_frame_data_t *frame_data)
Reading frame data function function.
err_t a5000plugntrust_get_applet_info(a5000plugntrust_t *ctx, a5000plugntrust_version_info_t *ver_info)
Get Version info from Applet.
err_t a5000plugntrust_get_tlv_u8buf(uint8_t *buf, uint32_t *buf_index, uint8_t buf_len, uint8_t tag, uint8_t *rsp, uint32_t *rsp_len)
Parses TLV data from payload buffer to find data for desired tag.
i2c_master_t i2c
Definition: a5000plugntrust.h:592
@ A5000PLUGNTRUST_ERROR_TIMEOUT
Definition: a5000plugntrust.h:691
err_t a5000plugntrust_end_apdu_session(a5000plugntrust_t *ctx)
Sends command for ending APDU session.
APDU data object.
Definition: a5000plugntrust.h:620
err_t a5000plugntrust_delete_object(a5000plugntrust_t *ctx, uint32_t object_id)
Delete object.
err_t a5000plugntrust_select_card_manager(a5000plugntrust_t *ctx, uint8_t rsp, uint8_t *cardmanager_rsp, uint8_t *cardmanager_rsp_len)
Select card manager.
err_t a5000plugntrust_sw_reset(a5000plugntrust_t *ctx, a5000plugntrust_atr_t *atr_data)
Sends request to reset device and reads ATR data.
uint8_t ins
Definition: a5000plugntrust.h:622
uint8_t slave_address
Definition: a5000plugntrust.h:595
void a5000plugntrust_set_tlv_u8(uint8_t *buf, uint8_t *buf_len, uint8_t tag, uint8_t value)
Add TLV data of 1 byte value in payload buffer.
uint8_t data_link_layer_parameters_len
Definition: a5000plugntrust.h:655
err_t a5000plugntrust_get_tlv_u8(uint8_t *buf, uint32_t *buf_index, uint8_t tag, uint8_t *rsp)
Parses TLV data from payload buffer to find data for desired tag.
pin_name_t en
Definition: a5000plugntrust.h:608
uint8_t payload_len
Definition: a5000plugntrust.h:625
uint32_t i2c_speed
Definition: a5000plugntrust.h:610
uint8_t physical_layer_parameters_len
Definition: a5000plugntrust.h:660
uint16_t secure_box
Definition: a5000plugntrust.h:679
err_t a5000plugntrust_init(a5000plugntrust_t *ctx, a5000plugntrust_cfg_t *cfg)
A5000 Plug n Trust initialization function.
uint8_t physical_layer_id
Definition: a5000plugntrust.h:658
err_t a5000plugntrust_write_binary_object(a5000plugntrust_t *ctx, uint32_t object_id, uint16_t offset, uint16_t data_len, uint8_t *data_buf)
Create/Write to binary object.
err_t a5000plugntrust_apdu_write(a5000plugntrust_t *ctx, a5000plugntrust_frame_data_t *frame_data)
Writing frame data function.
Communication frame data object.
Definition: a5000plugntrust.h:637
uint16_t rsp_len
Definition: a5000plugntrust.h:627
uint16_t applet_config
Definition: a5000plugntrust.h:678
uint8_t i2c_address
Definition: a5000plugntrust.h:611
err_t a5000plugntrust_get_tlv_u16(uint8_t *buf, uint32_t *buf_index, uint8_t tag, uint16_t *rsp)
Parses TLV data from payload buffer to find data for desired tag.
uint8_t major_version
Definition: a5000plugntrust.h:674
uint8_t historical_len
Definition: a5000plugntrust.h:663
void a5000plugntrust_cfg_setup(a5000plugntrust_cfg_t *cfg)
A5000 Plug n Trust configuration object setup function.
@ A5000PLUGNTRUST_ERROR_DATA_OVF
Definition: a5000plugntrust.h:692
uint8_t pcb
Definition: a5000plugntrust.h:639
void a5000plugntrust_set_tlv_u16(uint8_t *buf, uint8_t *buf_len, uint8_t tag, uint16_t value)
Add TLV data of 2 bytes value in payload buffer.
digital_out_t en
Definition: a5000plugntrust.h:589
err_t a5000plugntrust_set_tlv_u8buf(uint8_t *buf, uint8_t *buf_len, uint8_t tag, uint8_t *cmd, uint32_t cmd_len)
Add TLV data buffer in payload buffer.
uint16_t status
Definition: a5000plugntrust.h:628
Data after reset.
Definition: a5000plugntrust.h:651
uint8_t p2
Definition: a5000plugntrust.h:624
err_t a5000plugntrust_get_random_numbers(a5000plugntrust_t *ctx, uint8_t *random_buf, uint8_t buf_len)
Get random data.
pin_name_t scl
Definition: a5000plugntrust.h:605
A5000 Plug n Trust Click configuration object.
Definition: a5000plugntrust.h:604
err_t a5000plugntrust_get_free_memory(a5000plugntrust_t *ctx, uint8_t memory_type, uint16_t *free_memory)
Reads Applet free memory.
A5000 Plug n Trust Click context object.
Definition: a5000plugntrust.h:587
void a5000plugntrust_set_en(a5000plugntrust_t *ctx, uint8_t state)
Set Enable pin state.
err_t a5000plugntrust_check_object_exist(a5000plugntrust_t *ctx, uint32_t object_id)
Check if object exists.
uint8_t nad
Definition: a5000plugntrust.h:638
a5000plugntrust_apdu_t * apdu
Definition: a5000plugntrust.h:641
@ A5000PLUGNTRUST_ERROR
Definition: a5000plugntrust.h:690
pin_name_t sda
Definition: a5000plugntrust.h:606
err_t a5000plugntrust_select_applet(a5000plugntrust_t *ctx, uint8_t ns_encode, a5000plugntrust_version_info_t *ver_info)
Selects Clicks Applet and returns info that device sends back to host.
err_t a5000plugntrust_apdu_transfer(a5000plugntrust_t *ctx, a5000plugntrust_frame_data_t *frame_data)
Write-Read frame data function.
a5000plugntrust_return_value_t
A5000 Plug n Trust Click return value data.
Definition: a5000plugntrust.h:688
uint8_t p1
Definition: a5000plugntrust.h:623
void a5000plugntrust_set_tlv_u16_optional(uint8_t *buf, uint8_t *buf_len, uint8_t tag, uint16_t value)
Add TLV data of 2 bytes value in payload buffer if value is greater then 0.
uint8_t cla
Definition: a5000plugntrust.h:621
uint8_t a5000plugntrust_calculate_apdu_size(a5000plugntrust_apdu_t *apdu_data)
Calculates APDU object size.
uint8_t minor_version
Definition: a5000plugntrust.h:675
uint8_t patch_version
Definition: a5000plugntrust.h:676