Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Signal intention of system reset to firmware #214

Open
mchack-work opened this issue Apr 24, 2024 · 5 comments · May be fixed by #212
Open

Signal intention of system reset to firmware #214

mchack-work opened this issue Apr 24, 2024 · 5 comments · May be fixed by #212
Assignees
Labels
enhancement New feature or request fpga Related to the FPGA design
Milestone

Comments

@mchack-work
Copy link
Member

mchack-work commented Apr 24, 2024

Firmware is getting the possibility to load a preloaded app from flash. See #215

We need a way to indicate to the firmware the reason the running app want to do a reset.

Nota bene: This issue only covers hardware changes for how to send the intention to the firmware.

We should be able to signal a couple of intentions from the running app device to firmware:

  1. Reset, load and start a new app from client.
  2. Reset, load and start a new app from flash.
  3. Reset, load and start an app from client with a matching app hash.
  4. Reset, load and start an app from flash (where on flash?), matching an exact app hash.

Number 3 & 4 here means we need to communicate the app BLAKE2s hash of the next stage to the firmware.

If we want to be able to have general support for chaining apps and sharing data between them we also need to discuss how that sharing should be done. One idea is to reserve some RAM that won't get overwritten by firmware when resetting.

Also, see the investigation in docs/tkey_client_reset.md in internal repo about the bigger picture and threat model about how to initiate a reset signal from the client, which is orthogonal to this issue.

@mchack-work mchack-work linked a pull request Apr 24, 2024 that will close this issue
@mchack-work mchack-work added enhancement New feature or request fpga Related to the FPGA design labels Apr 25, 2024
@mchack-work mchack-work added this to the Codename Castor milestone Apr 25, 2024
@mchack-work
Copy link
Member Author

mchack-work commented May 16, 2024

Decision on meeting on 2024-05-16 to try to use a touch hold for this function. See attached PR.

Needs a software test. See #223

@dehanj
Copy link
Member

dehanj commented May 20, 2024

Started to investigate this, the touch sensor have a ~300 ms start up time, see attached picture. During this time the output from the touch sensor will be high, regardless of a touch or not. It seems to go low when it is ready.
This is most likely some power up sequence the touch IC needs, maybe calibration, maybe something else.

On top of this, the sensor is not registering a touch that started before the end of these 300 ms, meaning holding on the touch area and powering up the device, will not register a touch. The touch needs to start when the touch IC is ready.

Screenshot 2024-05-20 at 08 39 57

@SallSim
Copy link
Member

SallSim commented Sep 23, 2024

We will implement this with a protocol.

@SallSim SallSim closed this as not planned Won't fix, can't repro, duplicate, stale Sep 23, 2024
@mchack-work
Copy link
Member Author

mchack-work commented Sep 24, 2024

Our UX spec says we will use a client/app protocol request to ask for a system reset to load a new app from the client. The hardware support for system reset already exist (TK1_MMIO_TK1_SYSTEM_RESET).

However, we still have no way of communicating the device app's intent with a system reset to the firmware. The intent might be to just do a system reset because it's finished with it's work and start everything again, but it might also mean that the device app is calling system reset because the client asked it to, in order to load a new app from the client.

This means that, right now, the firmware will happily just start the preloaded app again and again. Clearly we need some way of communicating this intent to the firmware.

A couple of options:

  1. Extend the hardware system reset API to include the intent.
  2. Use some part of RAM to indicate intent.
  3. Use touch and finger detected instead, even though we have to wait until the sensor is ready and probably blink until a timeout, waiting for a touch.

For 2 above we might want to use some reserved way of doing this, like calling another system call in the firmware, and store the intent in FW_RAM instead, but that needs analysis.

Any more options? What's a good way forward? What are the threats, if any?

@mchack-work mchack-work reopened this Sep 24, 2024
@mchack-work mchack-work mentioned this issue Oct 26, 2024
10 tasks
@dehanj dehanj mentioned this issue Nov 14, 2024
12 tasks
@mchack-work mchack-work changed the title Signal to firmware not to load app from flash Signal intention of system reset Dec 10, 2024
@mchack-work
Copy link
Member Author

Updated main issue text.

@mchack-work mchack-work changed the title Signal intention of system reset Signal intention of system reset to firmware Jan 16, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request fpga Related to the FPGA design
Projects
None yet
Development

Successfully merging a pull request may close this issue.

4 participants