mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-18 11:21:11 +00:00
Poll USB during BIP39 derivation.
This patch adds calls to usbPoll in the progress callback. This should address #98. We call usbDelay instead of Poll, to call usbd_poll several times. Otherwise it would only handle one event instead of handling all events that were pending so far. The ugly magic number 5 is a guess. Note that we also need to set usbTiny, so that we don't recursively process messages. Since we don't know whether usbTiny is set, we need to store the old value (especially true for u2f). This fix also relies on another fix in libopencm3.
This commit is contained in:
parent
4ce4cc5605
commit
9287dd7e04
@ -39,6 +39,7 @@
|
|||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
#include "protect.h"
|
#include "protect.h"
|
||||||
#include "layout2.h"
|
#include "layout2.h"
|
||||||
|
#include "usb.h"
|
||||||
|
|
||||||
Storage storage;
|
Storage storage;
|
||||||
|
|
||||||
@ -337,6 +338,7 @@ void storage_setHomescreen(const uint8_t *data, uint32_t size)
|
|||||||
|
|
||||||
void get_root_node_callback(uint32_t iter, uint32_t total)
|
void get_root_node_callback(uint32_t iter, uint32_t total)
|
||||||
{
|
{
|
||||||
|
usbDelay(10); // handle up to ten usb interrupts.
|
||||||
layoutProgress("Waking up", 1000 * iter / total);
|
layoutProgress("Waking up", 1000 * iter / total);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -361,7 +363,9 @@ const uint8_t *storage_getSeed(bool usePassphrase)
|
|||||||
storage_show_error();
|
storage_show_error();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
char oldTiny = usbTiny(1);
|
||||||
mnemonic_to_seed(storage.mnemonic, usePassphrase ? sessionPassphrase : "", sessionSeed, get_root_node_callback); // BIP-0039
|
mnemonic_to_seed(storage.mnemonic, usePassphrase ? sessionPassphrase : "", sessionSeed, get_root_node_callback); // BIP-0039
|
||||||
|
usbTiny(oldTiny);
|
||||||
sessionSeedCached = true;
|
sessionSeedCached = true;
|
||||||
sessionSeedUsesPassphrase = usePassphrase;
|
sessionSeedUsesPassphrase = usePassphrase;
|
||||||
return sessionSeed;
|
return sessionSeed;
|
||||||
|
@ -419,9 +419,11 @@ void usbReconnect(void)
|
|||||||
usbd_disconnect(usbd_dev, 0);
|
usbd_disconnect(usbd_dev, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void usbTiny(char set)
|
char usbTiny(char set)
|
||||||
{
|
{
|
||||||
|
char old = tiny;
|
||||||
tiny = set;
|
tiny = set;
|
||||||
|
return old;
|
||||||
}
|
}
|
||||||
|
|
||||||
void usbDelay(int cycles)
|
void usbDelay(int cycles)
|
||||||
|
@ -23,7 +23,7 @@
|
|||||||
void usbInit(void);
|
void usbInit(void);
|
||||||
void usbPoll(void);
|
void usbPoll(void);
|
||||||
void usbReconnect(void);
|
void usbReconnect(void);
|
||||||
void usbTiny(char set);
|
char usbTiny(char set);
|
||||||
void usbDelay(int cycles);
|
void usbDelay(int cycles);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user