2018-09-06 16:28:56 +00:00
|
|
|
/*
|
|
|
|
* This file is part of the TREZOR project, https://trezor.io/
|
|
|
|
*
|
|
|
|
* Copyright (C) 2018 Pavol Rusnak <stick@satoshilabs.com>
|
|
|
|
*
|
|
|
|
* This library is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* along with this library. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2018-05-03 14:47:37 +00:00
|
|
|
#if DEBUG_LINK
|
|
|
|
|
2018-09-14 12:40:29 +00:00
|
|
|
void fsm_msgDebugLinkGetState(const DebugLinkGetState *msg)
|
2018-05-03 14:47:37 +00:00
|
|
|
{
|
|
|
|
(void)msg;
|
|
|
|
|
|
|
|
// Do not use RESP_INIT because it clears msg_resp, but another message
|
|
|
|
// might be being handled
|
|
|
|
DebugLinkState resp;
|
2019-01-23 16:00:01 +00:00
|
|
|
memzero(&resp, sizeof(resp));
|
2018-05-03 14:47:37 +00:00
|
|
|
|
|
|
|
resp.has_layout = true;
|
|
|
|
resp.layout.size = OLED_BUFSIZE;
|
|
|
|
memcpy(resp.layout.bytes, oledGetBuffer(), OLED_BUFSIZE);
|
|
|
|
|
2019-01-25 10:58:23 +00:00
|
|
|
if (config_hasPin()) {
|
2018-05-03 14:47:37 +00:00
|
|
|
resp.has_pin = true;
|
2019-01-25 10:58:23 +00:00
|
|
|
strlcpy(resp.pin, "1", sizeof(resp.pin));
|
2018-05-03 14:47:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
resp.has_matrix = true;
|
|
|
|
strlcpy(resp.matrix, pinmatrix_get(), sizeof(resp.matrix));
|
|
|
|
|
|
|
|
resp.has_reset_entropy = true;
|
|
|
|
resp.reset_entropy.size = reset_get_int_entropy(resp.reset_entropy.bytes);
|
|
|
|
|
|
|
|
resp.has_reset_word = true;
|
|
|
|
strlcpy(resp.reset_word, reset_get_word(), sizeof(resp.reset_word));
|
|
|
|
|
|
|
|
resp.has_recovery_fake_word = true;
|
|
|
|
strlcpy(resp.recovery_fake_word, recovery_get_fake_word(), sizeof(resp.recovery_fake_word));
|
|
|
|
|
|
|
|
resp.has_recovery_word_pos = true;
|
|
|
|
resp.recovery_word_pos = recovery_get_word_pos();
|
|
|
|
|
2019-02-07 15:06:07 +00:00
|
|
|
resp.has_mnemonic = config_getMnemonic(resp.mnemonic, sizeof(resp.mnemonic));
|
2018-05-03 14:47:37 +00:00
|
|
|
|
2019-01-25 10:58:23 +00:00
|
|
|
if (config_hasNode()) {
|
2018-05-03 14:47:37 +00:00
|
|
|
resp.has_node = true;
|
2019-01-25 10:58:23 +00:00
|
|
|
config_dumpNode(&(resp.node));
|
2018-05-03 14:47:37 +00:00
|
|
|
}
|
|
|
|
|
2019-02-07 15:06:07 +00:00
|
|
|
resp.has_passphrase_protection = config_getPassphraseProtection(&(resp.passphrase_protection));
|
2018-05-03 14:47:37 +00:00
|
|
|
|
|
|
|
msg_debug_write(MessageType_MessageType_DebugLinkState, &resp);
|
|
|
|
}
|
|
|
|
|
2018-09-14 12:40:29 +00:00
|
|
|
void fsm_msgDebugLinkStop(const DebugLinkStop *msg)
|
2018-05-03 14:47:37 +00:00
|
|
|
{
|
|
|
|
(void)msg;
|
|
|
|
}
|
|
|
|
|
2018-09-14 12:40:29 +00:00
|
|
|
void fsm_msgDebugLinkMemoryRead(const DebugLinkMemoryRead *msg)
|
2018-05-03 14:47:37 +00:00
|
|
|
{
|
|
|
|
RESP_INIT(DebugLinkMemory);
|
|
|
|
|
|
|
|
uint32_t length = 1024;
|
|
|
|
if (msg->has_length && msg->length < length)
|
|
|
|
length = msg->length;
|
|
|
|
resp->has_memory = true;
|
|
|
|
memcpy(resp->memory.bytes, FLASH_PTR(msg->address), length);
|
|
|
|
resp->memory.size = length;
|
|
|
|
msg_debug_write(MessageType_MessageType_DebugLinkMemory, resp);
|
|
|
|
}
|
|
|
|
|
2018-09-14 12:40:29 +00:00
|
|
|
void fsm_msgDebugLinkMemoryWrite(const DebugLinkMemoryWrite *msg)
|
2018-05-03 14:47:37 +00:00
|
|
|
{
|
|
|
|
uint32_t length = msg->memory.size;
|
|
|
|
if (msg->flash) {
|
|
|
|
svc_flash_unlock();
|
|
|
|
svc_flash_program(FLASH_CR_PROGRAM_X32);
|
|
|
|
for (uint32_t i = 0; i < length; i += 4) {
|
|
|
|
uint32_t word;
|
|
|
|
memcpy(&word, msg->memory.bytes + i, 4);
|
|
|
|
flash_write32(msg->address + i, word);
|
|
|
|
}
|
|
|
|
uint32_t dummy = svc_flash_lock();
|
|
|
|
(void)dummy;
|
|
|
|
} else {
|
|
|
|
#if !EMULATOR
|
|
|
|
memcpy((void *) msg->address, msg->memory.bytes, length);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-09-14 12:40:29 +00:00
|
|
|
void fsm_msgDebugLinkFlashErase(const DebugLinkFlashErase *msg)
|
2018-05-03 14:47:37 +00:00
|
|
|
{
|
|
|
|
svc_flash_unlock();
|
|
|
|
svc_flash_erase_sector(msg->sector);
|
|
|
|
uint32_t dummy = svc_flash_lock();
|
|
|
|
(void)dummy;
|
|
|
|
}
|
|
|
|
#endif
|