NFC refactoring (#3050)
"A long time ago in a galaxy far, far away...." we started NFC subsystem refactoring.
Starring:
- @gornekich - NFC refactoring project lead, architect, senior developer
- @gsurkov - architect, senior developer
- @RebornedBrain - senior developer
Supporting roles:
- @skotopes, @DrZlo13, @hedger - general architecture advisors, code review
- @Astrrra, @doomwastaken, @Hellitron, @ImagineVagon333 - quality assurance
Special thanks:
@bettse, @pcunning, @nxv, @noproto, @AloneLiberty and everyone else who has been helping us all this time and contributing valuable knowledges, ideas and source code.
2023-10-24 07:08:09 +04:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
#include "felica_poller.h"
|
|
|
|
|
#include <toolbox/bit_buffer.h>
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
extern "C" {
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#define FELICA_POLLER_MAX_BUFFER_SIZE (256U)
|
|
|
|
|
|
|
|
|
|
#define FELICA_POLLER_POLLING_FWT (200000U)
|
|
|
|
|
|
2024-07-15 07:38:49 +03:00
|
|
|
#define FELICA_POLLER_CMD_POLLING_REQ_CODE (0x00U)
|
NFC refactoring (#3050)
"A long time ago in a galaxy far, far away...." we started NFC subsystem refactoring.
Starring:
- @gornekich - NFC refactoring project lead, architect, senior developer
- @gsurkov - architect, senior developer
- @RebornedBrain - senior developer
Supporting roles:
- @skotopes, @DrZlo13, @hedger - general architecture advisors, code review
- @Astrrra, @doomwastaken, @Hellitron, @ImagineVagon333 - quality assurance
Special thanks:
@bettse, @pcunning, @nxv, @noproto, @AloneLiberty and everyone else who has been helping us all this time and contributing valuable knowledges, ideas and source code.
2023-10-24 07:08:09 +04:00
|
|
|
#define FELICA_POLLER_CMD_POLLING_RESP_CODE (0x01U)
|
|
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
|
FelicaPollerStateIdle,
|
|
|
|
|
FelicaPollerStateActivated,
|
2025-10-12 03:39:38 +03:00
|
|
|
FelicaPollerStateListSystem,
|
|
|
|
|
FelicaPollerStateSelectSystemIndex,
|
2024-04-10 12:51:36 +03:00
|
|
|
FelicaPollerStateAuthenticateInternal,
|
|
|
|
|
FelicaPollerStateAuthenticateExternal,
|
2025-10-01 18:54:08 +04:00
|
|
|
FelicaPollerStateTraverseStandardSystem,
|
|
|
|
|
FelicaPollerStateReadStandardBlocks,
|
|
|
|
|
FelicaPollerStateReadLiteBlocks,
|
2024-04-10 12:51:36 +03:00
|
|
|
FelicaPollerStateReadSuccess,
|
|
|
|
|
FelicaPollerStateReadFailed,
|
|
|
|
|
|
|
|
|
|
FelicaPollerStateNum
|
NFC refactoring (#3050)
"A long time ago in a galaxy far, far away...." we started NFC subsystem refactoring.
Starring:
- @gornekich - NFC refactoring project lead, architect, senior developer
- @gsurkov - architect, senior developer
- @RebornedBrain - senior developer
Supporting roles:
- @skotopes, @DrZlo13, @hedger - general architecture advisors, code review
- @Astrrra, @doomwastaken, @Hellitron, @ImagineVagon333 - quality assurance
Special thanks:
@bettse, @pcunning, @nxv, @noproto, @AloneLiberty and everyone else who has been helping us all this time and contributing valuable knowledges, ideas and source code.
2023-10-24 07:08:09 +04:00
|
|
|
} FelicaPollerState;
|
|
|
|
|
|
|
|
|
|
struct FelicaPoller {
|
|
|
|
|
Nfc* nfc;
|
|
|
|
|
FelicaPollerState state;
|
2024-04-10 12:51:36 +03:00
|
|
|
FelicaAuthentication auth;
|
|
|
|
|
|
NFC refactoring (#3050)
"A long time ago in a galaxy far, far away...." we started NFC subsystem refactoring.
Starring:
- @gornekich - NFC refactoring project lead, architect, senior developer
- @gsurkov - architect, senior developer
- @RebornedBrain - senior developer
Supporting roles:
- @skotopes, @DrZlo13, @hedger - general architecture advisors, code review
- @Astrrra, @doomwastaken, @Hellitron, @ImagineVagon333 - quality assurance
Special thanks:
@bettse, @pcunning, @nxv, @noproto, @AloneLiberty and everyone else who has been helping us all this time and contributing valuable knowledges, ideas and source code.
2023-10-24 07:08:09 +04:00
|
|
|
FelicaData* data;
|
|
|
|
|
BitBuffer* tx_buffer;
|
|
|
|
|
BitBuffer* rx_buffer;
|
|
|
|
|
|
|
|
|
|
NfcGenericEvent general_event;
|
|
|
|
|
FelicaPollerEvent felica_event;
|
|
|
|
|
FelicaPollerEventData felica_event_data;
|
|
|
|
|
NfcGenericCallback callback;
|
2024-04-10 12:51:36 +03:00
|
|
|
uint8_t block_index;
|
2025-10-12 03:39:38 +03:00
|
|
|
uint8_t systems_read;
|
|
|
|
|
uint8_t systems_total;
|
NFC refactoring (#3050)
"A long time ago in a galaxy far, far away...." we started NFC subsystem refactoring.
Starring:
- @gornekich - NFC refactoring project lead, architect, senior developer
- @gsurkov - architect, senior developer
- @RebornedBrain - senior developer
Supporting roles:
- @skotopes, @DrZlo13, @hedger - general architecture advisors, code review
- @Astrrra, @doomwastaken, @Hellitron, @ImagineVagon333 - quality assurance
Special thanks:
@bettse, @pcunning, @nxv, @noproto, @AloneLiberty and everyone else who has been helping us all this time and contributing valuable knowledges, ideas and source code.
2023-10-24 07:08:09 +04:00
|
|
|
void* context;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
|
uint16_t system_code;
|
|
|
|
|
uint8_t request_code;
|
|
|
|
|
uint8_t time_slot;
|
|
|
|
|
} FelicaPollerPollingCommand;
|
|
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
|
FelicaIDm idm;
|
|
|
|
|
FelicaPMm pmm;
|
|
|
|
|
uint8_t request_data[2];
|
|
|
|
|
} FelicaPollerPollingResponse;
|
|
|
|
|
|
2025-10-01 18:54:08 +04:00
|
|
|
typedef union {
|
|
|
|
|
FelicaData* data;
|
|
|
|
|
} FelicaPollerContextData;
|
|
|
|
|
|
NFC refactoring (#3050)
"A long time ago in a galaxy far, far away...." we started NFC subsystem refactoring.
Starring:
- @gornekich - NFC refactoring project lead, architect, senior developer
- @gsurkov - architect, senior developer
- @RebornedBrain - senior developer
Supporting roles:
- @skotopes, @DrZlo13, @hedger - general architecture advisors, code review
- @Astrrra, @doomwastaken, @Hellitron, @ImagineVagon333 - quality assurance
Special thanks:
@bettse, @pcunning, @nxv, @noproto, @AloneLiberty and everyone else who has been helping us all this time and contributing valuable knowledges, ideas and source code.
2023-10-24 07:08:09 +04:00
|
|
|
const FelicaData* felica_poller_get_data(FelicaPoller* instance);
|
|
|
|
|
|
2024-04-10 12:51:36 +03:00
|
|
|
/**
|
|
|
|
|
* @brief Performs felica polling operation as part of the activation process
|
|
|
|
|
*
|
|
|
|
|
* @param[in, out] instance pointer to the instance to be used in the transaction.
|
|
|
|
|
* @param[in] cmd Pointer to polling command structure
|
|
|
|
|
* @param[out] resp Pointer to the response structure
|
|
|
|
|
* @return FelicaErrorNone on success, an error code on failure
|
|
|
|
|
*/
|
2023-11-15 12:32:45 +04:00
|
|
|
FelicaError felica_poller_polling(
|
NFC refactoring (#3050)
"A long time ago in a galaxy far, far away...." we started NFC subsystem refactoring.
Starring:
- @gornekich - NFC refactoring project lead, architect, senior developer
- @gsurkov - architect, senior developer
- @RebornedBrain - senior developer
Supporting roles:
- @skotopes, @DrZlo13, @hedger - general architecture advisors, code review
- @Astrrra, @doomwastaken, @Hellitron, @ImagineVagon333 - quality assurance
Special thanks:
@bettse, @pcunning, @nxv, @noproto, @AloneLiberty and everyone else who has been helping us all this time and contributing valuable knowledges, ideas and source code.
2023-10-24 07:08:09 +04:00
|
|
|
FelicaPoller* instance,
|
|
|
|
|
const FelicaPollerPollingCommand* cmd,
|
|
|
|
|
FelicaPollerPollingResponse* resp);
|
|
|
|
|
|
2024-04-10 12:51:36 +03:00
|
|
|
/**
|
|
|
|
|
* @brief Performs felica write operation with data provided as parameters
|
|
|
|
|
*
|
|
|
|
|
* @param[in, out] instance pointer to the instance to be used in the transaction.
|
|
|
|
|
* @param[in] block_count Amount of blocks involved in writing procedure
|
|
|
|
|
* @param[in] block_numbers Array with block indexes according to felica docs
|
|
|
|
|
* @param[in] data Data of blocks provided in block_numbers
|
|
|
|
|
* @param[out] response_ptr Pointer to the response structure
|
|
|
|
|
* @return FelicaErrorNone on success, an error code on failure.
|
|
|
|
|
*/
|
|
|
|
|
FelicaError felica_poller_write_blocks(
|
|
|
|
|
const FelicaPoller* instance,
|
|
|
|
|
const uint8_t block_count,
|
|
|
|
|
const uint8_t* const block_numbers,
|
|
|
|
|
const uint8_t* data,
|
|
|
|
|
FelicaPollerWriteCommandResponse** const response_ptr);
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief Perform frame exchange procedure.
|
|
|
|
|
*
|
|
|
|
|
* Prepares data for sending by adding crc, after that performs
|
|
|
|
|
* low level calls to send package data to the card
|
|
|
|
|
*
|
|
|
|
|
* @param[in, out] instance pointer to the instance to be used in the transaction.
|
|
|
|
|
* @param[in] tx_buffer pointer to the buffer with data to be transmitted
|
|
|
|
|
* @param[out] rx_buffer pointer to the buffer with received data from card
|
|
|
|
|
* @param[in] fwt timeout window
|
|
|
|
|
* @return FelicaErrorNone on success, an error code on failure.
|
|
|
|
|
*/
|
|
|
|
|
FelicaError felica_poller_frame_exchange(
|
|
|
|
|
const FelicaPoller* instance,
|
|
|
|
|
const BitBuffer* tx_buffer,
|
|
|
|
|
BitBuffer* rx_buffer,
|
|
|
|
|
uint32_t fwt);
|
|
|
|
|
|
2025-10-01 18:54:08 +04:00
|
|
|
FelicaError felica_poller_list_service_by_cursor(
|
|
|
|
|
FelicaPoller* instance,
|
|
|
|
|
uint16_t cursor,
|
|
|
|
|
FelicaListServiceCommandResponse** response_ptr);
|
|
|
|
|
|
2025-10-12 03:39:38 +03:00
|
|
|
FelicaError felica_poller_list_system_code(
|
|
|
|
|
FelicaPoller* instance,
|
|
|
|
|
FelicaListSystemCodeCommandResponse** response_ptr);
|
|
|
|
|
|
NFC refactoring (#3050)
"A long time ago in a galaxy far, far away...." we started NFC subsystem refactoring.
Starring:
- @gornekich - NFC refactoring project lead, architect, senior developer
- @gsurkov - architect, senior developer
- @RebornedBrain - senior developer
Supporting roles:
- @skotopes, @DrZlo13, @hedger - general architecture advisors, code review
- @Astrrra, @doomwastaken, @Hellitron, @ImagineVagon333 - quality assurance
Special thanks:
@bettse, @pcunning, @nxv, @noproto, @AloneLiberty and everyone else who has been helping us all this time and contributing valuable knowledges, ideas and source code.
2023-10-24 07:08:09 +04:00
|
|
|
#ifdef __cplusplus
|
|
|
|
|
}
|
|
|
|
|
#endif
|