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

15693 listener can get get into a failed in some noisy conditions and remain there until restart #3343

Open
nvx opened this issue Jan 5, 2024 · 0 comments
Assignees
Labels
Bug NFC NFC-related

Comments

@nvx
Copy link
Contributor

nvx commented Jan 5, 2024

Describe the bug.

While tracking down some bugs I suspect were introduced with the NFC refactor I discovered an interesting condition that can occur in the 15693 emulation code.

In signal_reader_callback in iso15693_parser.c when a SOF is recieved it then sets the expected demodulation mode to either 1or4 or 1or256 depending on what the SOF looked like. After this mode has been set remaining calls to the callback look for data encoded in that modulation only. The issue is that readers will generally only use one of the two modulations exclusively (for example picopass only supports the higher speed 1of4 mode) and there is no timeout that resets the state back to Iso15693ParserStateParseSoF, so under real world conditions sometimes a bit of noise can trigger the wrong mode at which point emulation will stop working until it is manually restarted as we never encounter the appropriate end of frame.

I'd expect that the demodulator would upon encountering invalid modulation reset the state back to Iso15693ParserStateParseSoF so that it can start from the beginning again.

Reproduction

  1. Attach debugger
  2. Run picopass and emulate a credential
  3. Read the credential a bunch of times from varying distances (note at some point you may run into BusFault in furi hal doing picopass emulation flipperzero-good-faps#105 as well)
  4. When emulation stops working (everything looks fine on the FZ side of things, but the reader will not be able to see anything) add a breakpoint on the signal_reader_callback function
  5. Observe that instance->state is Iso15693ParserStateParseFrame and instance->mode is Iso15693ParserMode1OutOf256 which isn't used by picopass and that in all subsequent calls to this function the state and mode remains unchanged

Target

No response

Logs

No response

Anything else?

No response

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Bug NFC NFC-related
Projects
None yet
Development

No branches or pull requests

3 participants