1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-07 05:51:38 +00:00

chore(core): decrease base and handlers by 300 bytes

This commit is contained in:
grdddj 2022-09-20 12:22:45 +02:00 committed by matejcik
parent 0c8528821f
commit 16f1d3da86
2 changed files with 76 additions and 72 deletions

View File

@ -1,7 +1,7 @@
from typing import TYPE_CHECKING from typing import TYPE_CHECKING
import storage.cache import storage.cache as storage_cache
import storage.device import storage.device as storage_device
from trezor import config, utils, wire, workflow from trezor import config, utils, wire, workflow
from trezor.enums import MessageType from trezor.enums import MessageType
from trezor.messages import Success, UnlockPath from trezor.messages import Success, UnlockPath
@ -24,12 +24,24 @@ if TYPE_CHECKING:
) )
_ALLOW_WHILE_LOCKED = (
MessageType.Initialize,
MessageType.EndSession,
MessageType.GetFeatures,
MessageType.Cancel,
MessageType.LockDevice,
MessageType.DoPreauthorized,
MessageType.WipeDevice,
MessageType.SetBusy,
)
def busy_expiry_ms() -> int: def busy_expiry_ms() -> int:
""" """
Returns the time left until the busy state expires or 0 if the device is not in the busy state. Returns the time left until the busy state expires or 0 if the device is not in the busy state.
""" """
busy_deadline_ms = storage.cache.get_int(storage.cache.APP_COMMON_BUSY_DEADLINE_MS) busy_deadline_ms = storage_cache.get_int(storage_cache.APP_COMMON_BUSY_DEADLINE_MS)
if busy_deadline_ms is None: if busy_deadline_ms is None:
return 0 return 0
@ -40,9 +52,8 @@ def busy_expiry_ms() -> int:
def get_features() -> Features: def get_features() -> Features:
import storage.recovery import storage.recovery as storage_recovery
import storage.sd_salt import storage.sd_salt as storage_sd_salt
import storage # workaround for https://github.com/microsoft/pyright/issues/2685
from trezor import sdcard from trezor import sdcard
from trezor.enums import Capability from trezor.enums import Capability
@ -59,8 +70,8 @@ def get_features() -> Features:
patch_version=utils.VERSION_PATCH, patch_version=utils.VERSION_PATCH,
revision=utils.SCM_REVISION, revision=utils.SCM_REVISION,
model=utils.MODEL, model=utils.MODEL,
device_id=storage.device.get_device_id(), device_id=storage_device.get_device_id(),
label=storage.device.get_label(), label=storage_device.get_label(),
pin_protection=config.has_pin(), pin_protection=config.has_pin(),
unlocked=config.is_unlocked(), unlocked=config.is_unlocked(),
busy=busy_expiry_ms() > 0, busy=busy_expiry_ms() > 0,
@ -97,35 +108,35 @@ def get_features() -> Features:
f.capabilities.append(Capability.PassphraseEntry) f.capabilities.append(Capability.PassphraseEntry)
f.sd_card_present = sdcard.is_present() f.sd_card_present = sdcard.is_present()
f.initialized = storage.device.is_initialized() f.initialized = storage_device.is_initialized()
# private fields: # private fields:
if config.is_unlocked(): if config.is_unlocked():
# passphrase_protection is private, see #1807 # passphrase_protection is private, see #1807
f.passphrase_protection = storage.device.is_passphrase_enabled() f.passphrase_protection = storage_device.is_passphrase_enabled()
f.needs_backup = storage.device.needs_backup() f.needs_backup = storage_device.needs_backup()
f.unfinished_backup = storage.device.unfinished_backup() f.unfinished_backup = storage_device.unfinished_backup()
f.no_backup = storage.device.no_backup() f.no_backup = storage_device.no_backup()
f.flags = storage.device.get_flags() f.flags = storage_device.get_flags()
f.recovery_mode = storage.recovery.is_in_progress() f.recovery_mode = storage_recovery.is_in_progress()
f.backup_type = mnemonic.get_type() f.backup_type = mnemonic.get_type()
f.sd_protection = storage.sd_salt.is_enabled() f.sd_protection = storage_sd_salt.is_enabled()
f.wipe_code_protection = config.has_wipe_code() f.wipe_code_protection = config.has_wipe_code()
f.passphrase_always_on_device = storage.device.get_passphrase_always_on_device() f.passphrase_always_on_device = storage_device.get_passphrase_always_on_device()
f.safety_checks = safety_checks.read_setting() f.safety_checks = safety_checks.read_setting()
f.auto_lock_delay_ms = storage.device.get_autolock_delay_ms() f.auto_lock_delay_ms = storage_device.get_autolock_delay_ms()
f.display_rotation = storage.device.get_rotation() f.display_rotation = storage_device.get_rotation()
f.experimental_features = storage.device.get_experimental_features() f.experimental_features = storage_device.get_experimental_features()
return f return f
async def handle_Initialize(ctx: wire.Context, msg: Initialize) -> Features: async def handle_Initialize(ctx: wire.Context, msg: Initialize) -> Features:
session_id = storage.cache.start_session(msg.session_id) session_id = storage_cache.start_session(msg.session_id)
if not utils.BITCOIN_ONLY: if not utils.BITCOIN_ONLY:
derive_cardano = storage.cache.get(storage.cache.APP_COMMON_DERIVE_CARDANO) derive_cardano = storage_cache.get(storage_cache.APP_COMMON_DERIVE_CARDANO)
have_seed = storage.cache.is_set(storage.cache.APP_COMMON_SEED) have_seed = storage_cache.is_set(storage_cache.APP_COMMON_SEED)
if ( if (
have_seed have_seed
@ -134,13 +145,13 @@ async def handle_Initialize(ctx: wire.Context, msg: Initialize) -> Features:
): ):
# seed is already derived, and host wants to change derive_cardano setting # seed is already derived, and host wants to change derive_cardano setting
# => create a new session # => create a new session
storage.cache.end_current_session() storage_cache.end_current_session()
session_id = storage.cache.start_session() session_id = storage_cache.start_session()
have_seed = False have_seed = False
if not have_seed: if not have_seed:
storage.cache.set( storage_cache.set(
storage.cache.APP_COMMON_DERIVE_CARDANO, storage_cache.APP_COMMON_DERIVE_CARDANO,
b"\x01" if msg.derive_cardano else b"", b"\x01" if msg.derive_cardano else b"",
) )
@ -163,23 +174,23 @@ async def handle_LockDevice(ctx: wire.Context, msg: LockDevice) -> Success:
async def handle_SetBusy(ctx: wire.Context, msg: SetBusy) -> Success: async def handle_SetBusy(ctx: wire.Context, msg: SetBusy) -> Success:
if not storage.device.is_initialized(): if not storage_device.is_initialized():
raise wire.NotInitialized("Device is not initialized") raise wire.NotInitialized("Device is not initialized")
if msg.expiry_ms: if msg.expiry_ms:
import utime import utime
deadline = utime.ticks_add(utime.ticks_ms(), msg.expiry_ms) deadline = utime.ticks_add(utime.ticks_ms(), msg.expiry_ms)
storage.cache.set_int(storage.cache.APP_COMMON_BUSY_DEADLINE_MS, deadline) storage_cache.set_int(storage_cache.APP_COMMON_BUSY_DEADLINE_MS, deadline)
else: else:
storage.cache.delete(storage.cache.APP_COMMON_BUSY_DEADLINE_MS) storage_cache.delete(storage_cache.APP_COMMON_BUSY_DEADLINE_MS)
set_homescreen() set_homescreen()
workflow.close_others() workflow.close_others()
return Success() return Success()
async def handle_EndSession(ctx: wire.Context, msg: EndSession) -> Success: async def handle_EndSession(ctx: wire.Context, msg: EndSession) -> Success:
storage.cache.end_current_session() storage_cache.end_current_session()
return Success() return Success()
@ -274,41 +285,30 @@ async def handle_CancelAuthorization(
return Success(message="Authorization cancelled") return Success(message="Authorization cancelled")
ALLOW_WHILE_LOCKED = (
MessageType.Initialize,
MessageType.EndSession,
MessageType.GetFeatures,
MessageType.Cancel,
MessageType.LockDevice,
MessageType.DoPreauthorized,
MessageType.WipeDevice,
MessageType.SetBusy,
)
def set_homescreen() -> None: def set_homescreen() -> None:
import storage.recovery import storage.recovery as storage_recovery
import storage # workaround for https://github.com/microsoft/pyright/issues/2685
if storage.cache.is_set(storage.cache.APP_COMMON_BUSY_DEADLINE_MS): set_default = workflow.set_default # local_cache_attribute
if storage_cache.is_set(storage_cache.APP_COMMON_BUSY_DEADLINE_MS):
from apps.homescreen.busyscreen import busyscreen from apps.homescreen.busyscreen import busyscreen
workflow.set_default(busyscreen) set_default(busyscreen)
elif not config.is_unlocked(): elif not config.is_unlocked():
from apps.homescreen.lockscreen import lockscreen from apps.homescreen.lockscreen import lockscreen
workflow.set_default(lockscreen) set_default(lockscreen)
elif storage.recovery.is_in_progress(): elif storage_recovery.is_in_progress():
from apps.management.recovery_device.homescreen import recovery_homescreen from apps.management.recovery_device.homescreen import recovery_homescreen
workflow.set_default(recovery_homescreen) set_default(recovery_homescreen)
else: else:
from apps.homescreen.homescreen import homescreen from apps.homescreen.homescreen import homescreen
workflow.set_default(homescreen) set_default(homescreen)
def lock_device() -> None: def lock_device() -> None:
@ -353,7 +353,7 @@ def get_pinlocked_handler(
if iface is usb.iface_debug: if iface is usb.iface_debug:
return orig_handler return orig_handler
if msg_type in ALLOW_WHILE_LOCKED: if msg_type in _ALLOW_WHILE_LOCKED:
return orig_handler return orig_handler
async def wrapper(ctx: wire.Context, msg: wire.Msg) -> protobuf.MessageType: async def wrapper(ctx: wire.Context, msg: wire.Msg) -> protobuf.MessageType:
@ -368,25 +368,29 @@ def reload_settings_from_storage() -> None:
from trezor import ui from trezor import ui
workflow.idle_timer.set( workflow.idle_timer.set(
storage.device.get_autolock_delay_ms(), lock_device_if_unlocked storage_device.get_autolock_delay_ms(), lock_device_if_unlocked
) )
wire.experimental_enabled = storage.device.get_experimental_features() wire.experimental_enabled = storage_device.get_experimental_features()
ui.display.orientation(storage.device.get_rotation()) ui.display.orientation(storage_device.get_rotation())
def boot() -> None: def boot() -> None:
workflow_handlers.register(MessageType.Initialize, handle_Initialize) MT = MessageType # local_cache_global
workflow_handlers.register(MessageType.GetFeatures, handle_GetFeatures)
workflow_handlers.register(MessageType.Cancel, handle_Cancel) # Register workflow handlers
workflow_handlers.register(MessageType.LockDevice, handle_LockDevice) for msg_type, handler in (
workflow_handlers.register(MessageType.EndSession, handle_EndSession) (MT.Initialize, handle_Initialize),
workflow_handlers.register(MessageType.Ping, handle_Ping) (MT.GetFeatures, handle_GetFeatures),
workflow_handlers.register(MessageType.DoPreauthorized, handle_DoPreauthorized) (MT.Cancel, handle_Cancel),
workflow_handlers.register(MessageType.UnlockPath, handle_UnlockPath) (MT.LockDevice, handle_LockDevice),
workflow_handlers.register( (MT.EndSession, handle_EndSession),
MessageType.CancelAuthorization, handle_CancelAuthorization (MT.Ping, handle_Ping),
) (MT.DoPreauthorized, handle_DoPreauthorized),
workflow_handlers.register(MessageType.SetBusy, handle_SetBusy) (MT.UnlockPath, handle_UnlockPath),
(MT.CancelAuthorization, handle_CancelAuthorization),
(MT.SetBusy, handle_SetBusy),
):
workflow_handlers.register(msg_type, handler) # type: ignore [cannot be assigned to type]
reload_settings_from_storage() reload_settings_from_storage()
if config.is_unlocked(): if config.is_unlocked():

View File

@ -1,8 +1,5 @@
from typing import TYPE_CHECKING from typing import TYPE_CHECKING
from trezor import utils
from trezor.enums import MessageType
if TYPE_CHECKING: if TYPE_CHECKING:
from trezor.wire import Handler, Msg from trezor.wire import Handler, Msg
from trezorio import WireInterface from trezorio import WireInterface
@ -16,7 +13,7 @@ def register(wire_type: int, handler: Handler[Msg]) -> None:
workflow_handlers[wire_type] = handler workflow_handlers[wire_type] = handler
def find_message_handler_module(msg_type: int) -> str: def _find_message_handler_module(msg_type: int) -> str:
"""Statically find the appropriate workflow handler. """Statically find the appropriate workflow handler.
For now, new messages must be registered by hand in the if-elif manner below. For now, new messages must be registered by hand in the if-elif manner below.
@ -26,6 +23,9 @@ def find_message_handler_module(msg_type: int) -> str:
- collecting everything as strings instead of importing directly means that we don't - collecting everything as strings instead of importing directly means that we don't
need to load any of the modules into memory until we actually need them need to load any of the modules into memory until we actually need them
""" """
from trezor.enums import MessageType
from trezor import utils
# debug # debug
if __debug__ and msg_type == MessageType.LoadDevice: if __debug__ and msg_type == MessageType.LoadDevice:
return "apps.debug.load_device" return "apps.debug.load_device"
@ -190,7 +190,7 @@ def find_registered_handler(iface: WireInterface, msg_type: int) -> Handler | No
return workflow_handlers[msg_type] return workflow_handlers[msg_type]
try: try:
modname = find_message_handler_module(msg_type) modname = _find_message_handler_module(msg_type)
handler_name = modname[modname.rfind(".") + 1 :] handler_name = modname[modname.rfind(".") + 1 :]
module = __import__(modname, None, None, (handler_name,), 0) module = __import__(modname, None, None, (handler_name,), 0)
return getattr(module, handler_name) return getattr(module, handler_name)