NFC shell transport
The NFC shell transport functionality allows you to receive shell commands remotely over the ISO-DEP (ISO14443-4A) protocol with any NFC polling device. It uses the Type 4 Tag (T4T) library.
The NFC shell transport is used by default in the NFC: Shell sample.
Overview
The NFC shell transport uses the NFC T4T library to emulate an NFC tag. The NFC tag is a passive device that sends a response to the NFC polling device. Data is exchanged over the raw ISO-DEP (ISO14443-4A) that is a block, half-duplex transmission protocol.
NFC data exchange
The first payload is always sent by the polling device. The NFC tag sends a response after receiving the payload from the polling device. The shell interface needs to exchange data in both directions and can be used also as the Logging subsystem backend. Therefore, the polling device needs to poll for data constantly.
If at least one of the communication sides does not have any data, it must send the payload containing one dummy byte. You can set this byte to any value on your polling device. The NFC shell answers with the payload that was started with the same byte as it was received from the polling device.
The NFC tag always responds to the polling device’s frame. A record payload always starts with a dummy one-byte header. Its value is not relevant and it is not checked by this library.
The following diagram illustrates various data exchange cases:
Requirements
This library has the following requirements:
The NFC callback function must be called from a thread context. To do so, ensure that the
CONFIG_NFC_THREAD_CALLBACK
Kconfig option is enabled. For a default configuration, the function is called from a system workqueue context. In the callback function, this library uses operating system primitives which cannot be used in an interrupt context.If library logs and a logger are enabled, it is not recommended to use the logger in the synchronous mode. Synchronous logs processing might result in high latency in NFC events processing that can cause instability of the NFC shell backend. If you need logs from this library, configure the logger to be in the deferred mode by setting the
CONFIG_LOG_MODE_DEFERRED
Kconfig option.
Configuration
Set the CONFIG_SHELL_NFC
Kconfig option to enable the NFC shell backend.
The following configuration options are available for this module:
CONFIG_SHELL_NFC_INIT_PRIORITY
sets the initialization priority for the NFC shell backend.
CONFIG_SHELL_NFC_BACKEND_TX_BUFFER
sets a size of the NFC T4T ISO-DEP response buffer. The size might depend on the maximum supported frame size for the polling device.
CONFIG_SHELL_NFC_BACKEND_TX_RING_BUFFER_SIZE
sets a size of the shell Tx ring buffer. It is used to buffer data from the shell interface through the NFC T4T transport that can start sending data only on the data reception from the polling device.
CONFIG_SHELL_NFC_BACKEND_RX_RING_BUFFER_SIZE
- sets a size of the shell Rx ring buffer. It handles shell incoming data from the NFC transport.
See the Kconfig help for details.
Usage
You can set the CONFIG_SHELL_NFC
Kconfig option to enable the NFC shell.
The shell is initialized automatically during the system initialization.
You can approach your polling device that uses the raw ISO-DEP (ISO14443-4A) protocol to start the shell interface. Next, forward the received data to the terminal and send back data received from terminal through your polling device. For example, the terminal data can be the keyboard data or the bulk data.
Note
The NFC transport can be physically disconnected at any time. After disconnection, all data sent by the shell will be discarded. All uncompleted commands sent by the polling device before the disconnection are discarded as well. Every transport connection or re-connection starts a new shell session.
Samples using the library
The NFC: Shell nRF Connect SDK sample uses this library.
Limitations
The NFC T4T ISO-DEP transport is relatively slow - the maximum bit rate for NFC-A technology is 106 kbps.
The polling device needs to send data first or to send dummy data to poll data from the tag.
As a result, latency visible to the unaided eye occurs during printing characters in the terminal.
Moreover, it is not recommended to set the NFC shell as a logger backend due to the transport speed.
You can enable the CONFIG_SHELL_NFC_INIT_LOG_LEVEL_NONE
Kconfig option so that set the initial log level to none
for the NFC shell.
API documentation
include/shell/shell_nfc.h
subsys/shell/shell_nfc.c
- group shell_nfc
NFC shell transport API.
Functions
-
const struct shell *shell_backend_nfc_get_ptr(void)
This function provides a pointer to the shell NFC backend instance.
The function returns a pointer to the shell NFC instance. This instance can then be used with the shell_execute_cmd function to test the behavior of the command.
- Returns:
Pointer to the shell instance.
-
const struct shell *shell_backend_nfc_get_ptr(void)