mirror of
https://github.com/DarkFlippers/unleashed-firmware.git
synced 2024-12-02 12:13:16 +03:00
917410a0a8
* fbt: reworking targets & assets handling WIP * fbt: dist fixes * fbt: moved SD card resources to owning apps * unit_tests: moved resources to app folder * github: updated unit_tests paths * github: packaging fixes * unit_tests: fixes * fbt: assets: internal cleanup * fbt: reworked assets handling * github: unit_tests: reintroducing fixes * minor cleanup * fbt: naming changes to reflect private nature of scons tools * fbt: resources: fixed dist archive paths * docs: updated paths * docs: updated more paths * docs: included "resources" parameter in app manifest docs; updated assets readme * updated gitignore for assets * github: updated action versions * unit_tests: restored timeout; scripts: assets: logging changes * gh: don't upload desktop animations for unit test run Co-authored-by: あく <alleteam@gmail.com>
168 lines
5.9 KiB
C
168 lines
5.9 KiB
C
/**
|
|
* @file furi_hal_nfc_tech_i.h
|
|
* @brief NFC HAL technology-related private definitions.
|
|
*
|
|
* This file is an implementation detail. It must not be included in
|
|
* any public API-related headers.
|
|
*
|
|
* This file is to be changed in an unlikely event of adding support
|
|
* for a new NFC technology.
|
|
*/
|
|
#pragma once
|
|
|
|
#include <furi_hal_nfc.h>
|
|
#include <furi_hal_spi.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @brief Configure the NFC chip for use with this technology.
|
|
*
|
|
* Used for init() and deinit() functions.
|
|
*
|
|
* @param[in,out] handle pointer to the NFC chip SPI handle.
|
|
* @returns FuriHalNfcErrorNone on success, any other error code on failure.
|
|
*/
|
|
typedef FuriHalNfcError (*FuriHalNfcChipConfig)(FuriHalSpiBusHandle* handle);
|
|
|
|
/**
|
|
* @brief Transmit data using technology-specific framing and timings.
|
|
*
|
|
* @param[in,out] handle pointer to the NFC chip SPI handle.
|
|
* @param[in] tx_data pointer to a byte array containing the data to be transmitted.
|
|
* @param[in] tx_bits transmit data size, in bits.
|
|
* @returns FuriHalNfcErrorNone on success, any other error code on failure.
|
|
*/
|
|
typedef FuriHalNfcError (
|
|
*FuriHalNfcTx)(FuriHalSpiBusHandle* handle, const uint8_t* tx_data, size_t tx_bits);
|
|
|
|
/**
|
|
* @brief Receive data using technology-specific framing and timings.
|
|
*
|
|
* @param[in,out] handle pointer to the NFC chip SPI handle.
|
|
* @param[out] rx_data pointer to a byte array to be filled with received data.
|
|
* @param[in] rx_data_size maximum received data length, in bytes.
|
|
* @param[out] rx_bits pointer to a variable to contain received data length, in bits.
|
|
* @returns FuriHalNfcErrorNone on success, any other error code on failure.
|
|
*/
|
|
typedef FuriHalNfcError (*FuriHalNfcRx)(
|
|
FuriHalSpiBusHandle* handle,
|
|
uint8_t* rx_data,
|
|
size_t rx_data_size,
|
|
size_t* rx_bits);
|
|
|
|
/**
|
|
* @brief Wait for an event using technology-specific method.
|
|
*
|
|
* @param[in] timeout_ms maximum time to wait, in milliseconds.
|
|
* @return bitmask of occurred events.
|
|
*/
|
|
typedef FuriHalNfcEvent (*FuriHalNfcWaitEvent)(uint32_t timeout_ms);
|
|
|
|
/**
|
|
* @brief Go to sleep in listener mode.
|
|
*
|
|
* Puts the passive target logic into Sleep (Halt) state.
|
|
*
|
|
* @param[in,out] handle pointer to the NFC chip SPI handle.
|
|
* @returns FuriHalNfcErrorNone on success, any other error code on failure.
|
|
*/
|
|
typedef FuriHalNfcError (*FuriHalNfcSleep)(FuriHalSpiBusHandle* handle);
|
|
|
|
/**
|
|
* @brief Go to idle in listener mode.
|
|
*
|
|
* Puts the passive target logic into Sense (Idle) state.
|
|
*
|
|
* @param[in,out] handle pointer to the NFC chip SPI handle.
|
|
* @returns FuriHalNfcErrorNone on success, any other error code on failure.
|
|
*/
|
|
typedef FuriHalNfcError (*FuriHalNfcIdle)(FuriHalSpiBusHandle* handle);
|
|
|
|
/**
|
|
* @brief Technology-specific compenstaion values for pollers.
|
|
*
|
|
* Timing compensations are needed due to execution delays not accounted for
|
|
* in standards, they are usually found out experimentally.
|
|
*
|
|
* The compensation value will be subtracted from the respective timer running
|
|
* time, so positive values shorten timeouts, and negative ones make them longer.
|
|
*/
|
|
typedef struct {
|
|
int32_t fdt; /**< Frame delay time compensation, in carrier cycles. */
|
|
int32_t fwt; /**< Frame wait time compensaton, in carrier cycles. */
|
|
} FuriHalNfcPollerCompensation;
|
|
|
|
/**
|
|
* @brief Abstract technology-specific poller structure.
|
|
*/
|
|
typedef struct {
|
|
FuriHalNfcPollerCompensation compensation; /**< Compensation values in poller mode. */
|
|
FuriHalNfcChipConfig init; /**< Pointer to the init() function. */
|
|
FuriHalNfcChipConfig deinit; /**< Pointer to the deinit() function. */
|
|
FuriHalNfcWaitEvent wait_event; /**< Pointer to the wait_event() function. */
|
|
FuriHalNfcTx tx; /**< Pointer to the tx() function. */
|
|
FuriHalNfcRx rx; /**< Pointer to the rx() function. */
|
|
} FuriHalNfcTechPollerBase;
|
|
|
|
/**
|
|
* @brief Technology-specific compenstaion values for listeners.
|
|
*
|
|
* Same considerations apply as with FuriHalNfcPollerCompensation.
|
|
*/
|
|
typedef struct {
|
|
int32_t fdt; /**< Frame delay time compensation, in carrier cycles. */
|
|
} FuriHalNfcListenerCompensation;
|
|
|
|
/**
|
|
* @brief Abstract technology-specific listener structure.
|
|
*
|
|
* If the listener operating mode is not supported for a particular
|
|
* technology, fill this structure with zeroes.
|
|
*/
|
|
typedef struct {
|
|
FuriHalNfcListenerCompensation compensation; /**< Compensation values in listener mode. */
|
|
FuriHalNfcChipConfig init; /**< Pointer to the init() function. */
|
|
FuriHalNfcChipConfig deinit; /**< Pointer to the deinit() function. */
|
|
FuriHalNfcWaitEvent wait_event; /**< Pointer to the wait_event() function. */
|
|
FuriHalNfcTx tx; /**< Pointer to the tx() function. */
|
|
FuriHalNfcRx rx; /**< Pointer to the rx() function. */
|
|
FuriHalNfcSleep sleep; /**< Pointer to the sleep() function. */
|
|
FuriHalNfcIdle idle; /**< Pointer to the idle() function. */
|
|
} FuriHalNfcTechListenerBase;
|
|
|
|
/**
|
|
* @brief Abstract NFC technology definition structure.
|
|
*
|
|
* Each concrete technology implementation must fill this structure
|
|
* with its proper functions and constants.
|
|
*/
|
|
typedef struct {
|
|
FuriHalNfcTechPollerBase poller; /**< Structure containing the poller definition. */
|
|
FuriHalNfcTechListenerBase listener; /**< Structure containing the listener definition. */
|
|
} FuriHalNfcTechBase;
|
|
|
|
/** @brief Technology declaration for ISO14443 (Type A). */
|
|
extern const FuriHalNfcTechBase furi_hal_nfc_iso14443a;
|
|
/** @brief Technology declaration for ISO14443 (Type B). */
|
|
extern const FuriHalNfcTechBase furi_hal_nfc_iso14443b;
|
|
/** @brief Technology declaration for ISO15693. */
|
|
extern const FuriHalNfcTechBase furi_hal_nfc_iso15693;
|
|
/** @brief Technology declaration for FeliCa. */
|
|
extern const FuriHalNfcTechBase furi_hal_nfc_felica;
|
|
/* Declare new tehcnologies here. */
|
|
|
|
/**
|
|
* @brief Array of pointers to every supported technology.
|
|
*
|
|
* This variable is defined in furi_hal_nfc.c. It will need to be modified
|
|
* in case when a new technology is to be added.
|
|
*/
|
|
extern const FuriHalNfcTechBase* furi_hal_nfc_tech[];
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|