1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-20 12:21:01 +00:00

Convert U2F counter from private to public to take advantage of the more efficient implementation.

This commit is contained in:
andrew 2019-01-04 16:23:14 +01:00 committed by Pavol Rusnak
parent fa339bbe06
commit 8be3896038
No known key found for this signature in database
GPG Key ID: 91F3B339B9A02A3D
2 changed files with 16 additions and 3 deletions

View File

@ -8,7 +8,7 @@ from apps.common import cache
HOMESCREEN_MAXSIZE = 16384 HOMESCREEN_MAXSIZE = 16384
_STORAGE_VERSION = b"\x01" _STORAGE_VERSION = b"\x02"
_FALSE_BYTE = b"\x00" _FALSE_BYTE = b"\x00"
_TRUE_BYTE = b"\x01" _TRUE_BYTE = b"\x01"
_COUNTER_HEAD_LEN = 4 _COUNTER_HEAD_LEN = 4
@ -223,3 +223,15 @@ def set_u2f_counter(cntr: int) -> None:
def wipe(): def wipe():
config.wipe() config.wipe()
cache.clear() cache.clear()
def init_unlocked():
# Check for storage version upgrade.
version = config.get(_APP, _VERSION)
if version == b"\x01":
# Make the U2F counter public.
counter = config.get(_APP, _U2F_COUNTER)
if counter is not None:
_set_counter(_APP, _U2F_COUNTER, counter, True)
config.delete(_APP, _U2F_COUNTER)
config.set(_APP, _VERSION, _STORAGE_VERSION)

View File

@ -2,6 +2,7 @@ from trezor import config, log, loop, res, ui
from trezor.pin import pin_to_int, show_pin_timeout from trezor.pin import pin_to_int, show_pin_timeout
from apps.common.request_pin import request_pin from apps.common.request_pin import request_pin
from apps.common import storage
async def bootscreen(): async def bootscreen():
@ -9,12 +10,14 @@ async def bootscreen():
try: try:
if not config.has_pin(): if not config.has_pin():
config.unlock(pin_to_int("")) config.unlock(pin_to_int(""))
storage.init_unlocked()
return return
await lockscreen() await lockscreen()
label = None label = None
while True: while True:
pin = await request_pin(label, config.get_pin_rem()) pin = await request_pin(label, config.get_pin_rem())
if config.unlock(pin_to_int(pin)): if config.unlock(pin_to_int(pin)):
storage.init_unlocked()
return return
else: else:
label = "Wrong PIN, enter again" label = "Wrong PIN, enter again"
@ -24,8 +27,6 @@ async def bootscreen():
async def lockscreen(): async def lockscreen():
from apps.common import storage
label = storage.get_label() label = storage.get_label()
image = storage.get_homescreen() image = storage.get_homescreen()
if not label: if not label: