2021-10-03 10:36:05 +00:00
|
|
|
/**
|
|
|
|
* @file furi-hal-nfc.h
|
|
|
|
* NFC HAL API
|
|
|
|
*/
|
|
|
|
|
2021-08-08 18:03:25 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <rfal_nfc.h>
|
|
|
|
#include <st_errno.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define FURI_HAL_NFC_UID_MAX_LEN 10
|
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Init nfc
|
2021-08-08 18:03:25 +00:00
|
|
|
*/
|
|
|
|
void furi_hal_nfc_init();
|
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Check if nfc worker is busy
|
|
|
|
*
|
|
|
|
* @return true if busy
|
2021-08-08 18:03:25 +00:00
|
|
|
*/
|
|
|
|
bool furi_hal_nfc_is_busy();
|
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** NFC field on
|
2021-08-08 18:03:25 +00:00
|
|
|
*/
|
|
|
|
void furi_hal_nfc_field_on();
|
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** NFC field off
|
2021-08-08 18:03:25 +00:00
|
|
|
*/
|
|
|
|
void furi_hal_nfc_field_off();
|
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** NFC start sleep
|
2021-08-08 18:03:25 +00:00
|
|
|
*/
|
|
|
|
void furi_hal_nfc_start_sleep();
|
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** NFC stop sleep
|
2021-08-08 18:03:25 +00:00
|
|
|
*/
|
|
|
|
void furi_hal_nfc_exit_sleep();
|
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** NFC poll
|
|
|
|
*
|
|
|
|
* @param dev_list pointer to rfalNfcDevice buffer
|
|
|
|
* @param dev_cnt pointer device count
|
|
|
|
* @param timeout timeout in ms
|
|
|
|
* @param deactivate deactivate flag
|
|
|
|
*
|
|
|
|
* @return true on success
|
2021-08-08 18:03:25 +00:00
|
|
|
*/
|
|
|
|
bool furi_hal_nfc_detect(rfalNfcDevice** dev_list, uint8_t* dev_cnt, uint32_t timeout, bool deactivate);
|
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** NFC listen
|
|
|
|
*
|
|
|
|
* @param uid pointer to uid buffer
|
|
|
|
* @param uid_len uid length
|
|
|
|
* @param atqa pointer to atqa
|
|
|
|
* @param sak sak
|
|
|
|
* @param activate_after_sak activate after sak flag
|
|
|
|
* @param timeout timeout in ms
|
|
|
|
*
|
|
|
|
* @return true on success
|
2021-08-08 18:03:25 +00:00
|
|
|
*/
|
2021-08-16 21:45:04 +00:00
|
|
|
bool furi_hal_nfc_listen(uint8_t* uid, uint8_t uid_len, uint8_t* atqa, uint8_t sak, bool activate_after_sak, uint32_t timeout);
|
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Get first command from reader after activation in emulation mode
|
|
|
|
*
|
|
|
|
* @param rx_buff pointer to receive buffer
|
|
|
|
* @param rx_len receive buffer length
|
|
|
|
*
|
|
|
|
* @return true on success
|
2021-08-16 21:45:04 +00:00
|
|
|
*/
|
|
|
|
bool furi_hal_nfc_get_first_frame(uint8_t** rx_buff, uint16_t** rx_len);
|
2021-08-08 18:03:25 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** NFC data exchange
|
|
|
|
*
|
|
|
|
* @param tx_buff transmit buffer
|
|
|
|
* @param tx_len transmit buffer length
|
|
|
|
* @param rx_buff receive buffer
|
|
|
|
* @param rx_len receive buffer length
|
|
|
|
* @param deactivate deactivate flag
|
|
|
|
*
|
|
|
|
* @return ST ReturnCode
|
2021-08-08 18:03:25 +00:00
|
|
|
*/
|
|
|
|
ReturnCode furi_hal_nfc_data_exchange(uint8_t* tx_buff, uint16_t tx_len, uint8_t** rx_buff, uint16_t** rx_len, bool deactivate);
|
|
|
|
|
2021-12-21 12:33:17 +00:00
|
|
|
ReturnCode furi_hal_nfc_raw_bitstream_exchange(uint8_t* tx_buff, uint16_t tx_bit_len, uint8_t** rx_buff, uint16_t** rx_bit_len, bool deactivate);
|
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** NFC deactivate and start sleep
|
2021-08-08 18:03:25 +00:00
|
|
|
*/
|
|
|
|
void furi_hal_nfc_deactivate();
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|