mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-05 04:50:57 +00:00
feat(core): Implement Optiga counter operations.
This commit is contained in:
parent
aed5912fbf
commit
cb21ca8dc5
@ -67,4 +67,8 @@ int __wur optiga_pin_verify(OPTIGA_UI_PROGRESS ui_progress,
|
|||||||
const uint8_t pin_secret[OPTIGA_PIN_SECRET_SIZE],
|
const uint8_t pin_secret[OPTIGA_PIN_SECRET_SIZE],
|
||||||
uint8_t out_secret[OPTIGA_PIN_SECRET_SIZE]);
|
uint8_t out_secret[OPTIGA_PIN_SECRET_SIZE]);
|
||||||
|
|
||||||
|
int __wur optiga_pin_get_fails(uint32_t *ctr);
|
||||||
|
|
||||||
|
int __wur optiga_pin_fails_increase(uint32_t count);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -631,3 +631,36 @@ int optiga_pin_verify(OPTIGA_UI_PROGRESS ui_progress,
|
|||||||
OPTIGA_PIN_SECRET_SIZE, out_secret);
|
OPTIGA_PIN_SECRET_SIZE, out_secret);
|
||||||
return OPTIGA_SUCCESS;
|
return OPTIGA_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int optiga_get_counter(uint16_t oid, uint32_t *ctr) {
|
||||||
|
uint8_t counter[8] = {0};
|
||||||
|
size_t counter_size = 0;
|
||||||
|
optiga_result res = optiga_get_data_object(oid, false, counter,
|
||||||
|
sizeof(counter), &counter_size);
|
||||||
|
if (res != OPTIGA_SUCCESS) {
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (counter_size != sizeof(counter)) {
|
||||||
|
return OPTIGA_ERR_SIZE;
|
||||||
|
}
|
||||||
|
|
||||||
|
*ctr = counter[0];
|
||||||
|
*ctr = (*ctr << 8) + counter[1];
|
||||||
|
*ctr = (*ctr << 8) + counter[2];
|
||||||
|
*ctr = (*ctr << 8) + counter[3];
|
||||||
|
|
||||||
|
return OPTIGA_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
int optiga_pin_get_fails(uint32_t *ctr) {
|
||||||
|
return optiga_get_counter(OID_PIN_COUNTER, ctr);
|
||||||
|
}
|
||||||
|
|
||||||
|
int optiga_pin_fails_increase(uint32_t count) {
|
||||||
|
if (count > 0xff) {
|
||||||
|
return OPTIGA_ERR_PARAM;
|
||||||
|
}
|
||||||
|
|
||||||
|
return optiga_count_data_object(OID_PIN_COUNTER, count);
|
||||||
|
}
|
||||||
|
@ -338,6 +338,39 @@ optiga_result optiga_set_data_object(uint16_t oid, bool set_metadata,
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* https://github.com/Infineon/optiga-trust-m/blob/develop/documents/OPTIGA%E2%84%A2%20Trust%20M%20Solution%20Reference%20Manual.md#setdataobject
|
||||||
|
*/
|
||||||
|
optiga_result optiga_count_data_object(uint16_t oid, uint8_t count) {
|
||||||
|
if (count == 0) {
|
||||||
|
return OPTIGA_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
tx_size = 9;
|
||||||
|
if (tx_size > sizeof(tx_buffer)) {
|
||||||
|
return OPTIGA_ERR_PARAM;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint8_t *ptr = tx_buffer;
|
||||||
|
*(ptr++) = 0x82; // command code
|
||||||
|
*(ptr++) = 0x02; // count data object
|
||||||
|
write_uint16(&ptr, tx_size - 4);
|
||||||
|
|
||||||
|
write_uint16(&ptr, oid);
|
||||||
|
write_uint16(&ptr, 0); // offset
|
||||||
|
|
||||||
|
*(ptr++) = count;
|
||||||
|
|
||||||
|
optiga_result ret = optiga_execute_command(tx_buffer, tx_size, tx_buffer,
|
||||||
|
sizeof(tx_buffer), &tx_size);
|
||||||
|
if (ret != OPTIGA_SUCCESS) {
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
ret = process_output_fixedlen(NULL, 0);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* https://github.com/Infineon/optiga-trust-m/blob/develop/documents/OPTIGA%E2%84%A2%20Trust%20M%20Solution%20Reference%20Manual.md#getrandom
|
* https://github.com/Infineon/optiga-trust-m/blob/develop/documents/OPTIGA%E2%84%A2%20Trust%20M%20Solution%20Reference%20Manual.md#getrandom
|
||||||
*/
|
*/
|
||||||
|
@ -157,6 +157,7 @@ optiga_result optiga_get_data_object(uint16_t oid, bool get_metadata,
|
|||||||
size_t *data_size);
|
size_t *data_size);
|
||||||
optiga_result optiga_set_data_object(uint16_t oid, bool set_metadata,
|
optiga_result optiga_set_data_object(uint16_t oid, bool set_metadata,
|
||||||
const uint8_t *data, size_t data_size);
|
const uint8_t *data, size_t data_size);
|
||||||
|
optiga_result optiga_count_data_object(uint16_t oid, uint8_t count);
|
||||||
optiga_result optiga_get_random(uint8_t *random, size_t random_size);
|
optiga_result optiga_get_random(uint8_t *random, size_t random_size);
|
||||||
optiga_result optiga_encrypt_sym(optiga_sym_mode mode, uint16_t oid,
|
optiga_result optiga_encrypt_sym(optiga_sym_mode mode, uint16_t oid,
|
||||||
const uint8_t *input, size_t input_size,
|
const uint8_t *input, size_t input_size,
|
||||||
|
@ -167,3 +167,10 @@ int optiga_pin_verify(OPTIGA_UI_PROGRESS ui_progress,
|
|||||||
ui_progress(OPTIGA_PIN_DERIVE_MS);
|
ui_progress(OPTIGA_PIN_DERIVE_MS);
|
||||||
return OPTIGA_SUCCESS;
|
return OPTIGA_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int optiga_pin_get_fails(uint32_t *ctr) {
|
||||||
|
*ctr = 0;
|
||||||
|
return OPTIGA_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
int optiga_pin_fails_increase(uint32_t count) { return OPTIGA_SUCCESS; }
|
||||||
|
Loading…
Reference in New Issue
Block a user