mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-10 15:30:55 +00:00
throw UnexpectedMessage failure on unknown messages
This commit is contained in:
parent
1a1ba46e2c
commit
465ec2104b
@ -45,4 +45,3 @@ CFLAGS += -Iprotob -DPB_FIELD_16BIT=1
|
|||||||
CFLAGS += -DDEBUG_LINK=0
|
CFLAGS += -DDEBUG_LINK=0
|
||||||
CFLAGS += -DDEBUG_LOG=0
|
CFLAGS += -DDEBUG_LOG=0
|
||||||
CFLAGS += -DSCM_REVISION='"$(shell git rev-parse HEAD | sed 's:\(..\):\\x\1:g')"'
|
CFLAGS += -DSCM_REVISION='"$(shell git rev-parse HEAD | sed 's:\(..\):\\x\1:g')"'
|
||||||
CFLAGS += -DSCM_REVISION_LEN=20
|
|
||||||
|
@ -111,7 +111,8 @@ void fsm_msgInitialize(Initialize *msg)
|
|||||||
resp->has_pin_protection = true; resp->pin_protection = storage.has_pin;
|
resp->has_pin_protection = true; resp->pin_protection = storage.has_pin;
|
||||||
resp->has_passphrase_protection = true; resp->passphrase_protection = storage.has_passphrase_protection && storage.passphrase_protection;
|
resp->has_passphrase_protection = true; resp->passphrase_protection = storage.has_passphrase_protection && storage.passphrase_protection;
|
||||||
#ifdef SCM_REVISION
|
#ifdef SCM_REVISION
|
||||||
resp->has_revision = true; memcpy(resp->revision.bytes, SCM_REVISION, sizeof(resp->revision)); resp->revision.size = SCM_REVISION_LEN;
|
int len = sizeof(SCM_REVISION) - 1;
|
||||||
|
resp->has_revision = true; memcpy(resp->revision.bytes, SCM_REVISION, len); resp->revision.size = len;
|
||||||
#endif
|
#endif
|
||||||
resp->has_bootloader_hash = true; resp->bootloader_hash.size = memory_bootloader_hash(resp->bootloader_hash.bytes);
|
resp->has_bootloader_hash = true; resp->bootloader_hash.size = memory_bootloader_hash(resp->bootloader_hash.bytes);
|
||||||
if (storage.has_language) {
|
if (storage.has_language) {
|
||||||
|
@ -290,6 +290,8 @@ void msg_read_common(char type, uint8_t *buf, int len)
|
|||||||
static uint32_t msg_pos = 0;
|
static uint32_t msg_pos = 0;
|
||||||
static const pb_field_t *fields = 0;
|
static const pb_field_t *fields = 0;
|
||||||
|
|
||||||
|
if (len != 64) return;
|
||||||
|
|
||||||
if (read_state == READSTATE_IDLE) {
|
if (read_state == READSTATE_IDLE) {
|
||||||
if (buf[0] != '?' || buf[1] != '#' || buf[2] != '#') { // invalid start - discard
|
if (buf[0] != '?' || buf[1] != '#' || buf[2] != '#') { // invalid start - discard
|
||||||
return;
|
return;
|
||||||
@ -299,7 +301,7 @@ void msg_read_common(char type, uint8_t *buf, int len)
|
|||||||
|
|
||||||
fields = MessageFields(type, 'i', msg_id);
|
fields = MessageFields(type, 'i', msg_id);
|
||||||
if (!fields) { // unknown message
|
if (!fields) { // unknown message
|
||||||
// fsm_sendFailure(FailureType_Failure_UnexpectedMessage, "Unknown message");
|
fsm_sendFailure(FailureType_Failure_UnexpectedMessage, "Unknown message");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (msg_size > MSG_IN_SIZE) { // message is too big :(
|
if (msg_size > MSG_IN_SIZE) { // message is too big :(
|
||||||
@ -355,7 +357,7 @@ uint16_t msg_tiny_id = 0xFFFF;
|
|||||||
|
|
||||||
void msg_read_tiny(uint8_t *buf, int len)
|
void msg_read_tiny(uint8_t *buf, int len)
|
||||||
{
|
{
|
||||||
if (len < 9) return;
|
if (len != 64) return;
|
||||||
if (buf[0] != '?' || buf[1] != '#' || buf[2] != '#') {
|
if (buf[0] != '?' || buf[1] != '#' || buf[2] != '#') {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -402,7 +404,7 @@ void msg_read_tiny(uint8_t *buf, int len)
|
|||||||
msg_tiny_id = 0xFFFF;
|
msg_tiny_id = 0xFFFF;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// fsm_sendFailure(FailureType_Failure_UnexpectedMessage, "Unknown message");
|
fsm_sendFailure(FailureType_Failure_UnexpectedMessage, "Unknown message");
|
||||||
msg_tiny_id = 0xFFFF;
|
msg_tiny_id = 0xFFFF;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -34,8 +34,11 @@ bool protectAbortedByInitialize = false;
|
|||||||
bool protectButton(ButtonRequestType type, bool confirm_only)
|
bool protectButton(ButtonRequestType type, bool confirm_only)
|
||||||
{
|
{
|
||||||
ButtonRequest resp;
|
ButtonRequest resp;
|
||||||
bool result;
|
bool result = false;
|
||||||
bool acked = false;
|
bool acked = false;
|
||||||
|
#if DEBUG_LINK
|
||||||
|
bool debug_decided = false;
|
||||||
|
#endif
|
||||||
|
|
||||||
memset(&resp, 0, sizeof(ButtonRequest));
|
memset(&resp, 0, sizeof(ButtonRequest));
|
||||||
resp.has_code = true;
|
resp.has_code = true;
|
||||||
@ -46,7 +49,7 @@ bool protectButton(ButtonRequestType type, bool confirm_only)
|
|||||||
for (;;) {
|
for (;;) {
|
||||||
usbPoll();
|
usbPoll();
|
||||||
|
|
||||||
// wait for ButtonAck
|
// check for ButtonAck
|
||||||
if (msg_tiny_id == MessageType_MessageType_ButtonAck) {
|
if (msg_tiny_id == MessageType_MessageType_ButtonAck) {
|
||||||
msg_tiny_id = 0xFFFF;
|
msg_tiny_id = 0xFFFF;
|
||||||
acked = true;
|
acked = true;
|
||||||
@ -66,6 +69,7 @@ bool protectButton(ButtonRequestType type, bool confirm_only)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// check for Cancel / Initialize
|
||||||
if (msg_tiny_id == MessageType_MessageType_Cancel || msg_tiny_id == MessageType_MessageType_Initialize) {
|
if (msg_tiny_id == MessageType_MessageType_Cancel || msg_tiny_id == MessageType_MessageType_Initialize) {
|
||||||
if (msg_tiny_id == MessageType_MessageType_Initialize) {
|
if (msg_tiny_id == MessageType_MessageType_Initialize) {
|
||||||
protectAbortedByInitialize = true;
|
protectAbortedByInitialize = true;
|
||||||
@ -75,12 +79,16 @@ bool protectButton(ButtonRequestType type, bool confirm_only)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
// check debug link
|
|
||||||
#if DEBUG_LINK
|
#if DEBUG_LINK
|
||||||
|
// check DebugLink
|
||||||
if (msg_tiny_id == MessageType_MessageType_DebugLinkDecision) {
|
if (msg_tiny_id == MessageType_MessageType_DebugLinkDecision) {
|
||||||
msg_tiny_id = 0xFFFF;
|
msg_tiny_id = 0xFFFF;
|
||||||
DebugLinkDecision *dld = (DebugLinkDecision *)msg_tiny;
|
DebugLinkDecision *dld = (DebugLinkDecision *)msg_tiny;
|
||||||
result = dld->yes_no;
|
result = dld->yes_no;
|
||||||
|
debug_decided = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (acked && debug_decided) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user