mirror of
https://github.com/Next-Flip/Momentum-Firmware.git
synced 2026-04-25 03:29:58 -07:00
* New types for felica poller * New functions for felica data transmissions * Felica memory map extended with new fields * Init/deinit of mbedtls context added for felica encryption * Functions for session key and mac calculations added * Raw felica_poller implementation added * Removed MAC type parameter from check_mac function * Replaced all data fields needed for auth with context structure * Clean up felica_poller.c * Now RC block is filled with random numbers * New parameter for counting well-read blocks * Some cleanups * Felica file save and load logic added * Now we use card key from context for session key calculation * Copying card key to card block from auth context when both authentications succeeded, otherwise decrement blocks count by 1 * New felica poller event added * Moved some data structions to public namespace * FelicaAuthenticationContext struct moved to felica.h * Field type and name changed for better ones * Helper functions for felica_auth added to the app * New scene for felica card key input added * Logic for felica key input added * Auth context request processing added * Added block index definitions and replaced all index numbers with them * More macro defines * Replace nesting with do while block * New function for write operations mac calculation added * Replace nesting with do while block * Make functions static for now because they are used internally * Wrote some comments * Raw felica render implementation * New felica scenes * Adjusted felica dump rendering according design requirements * New felica scene added * Helper for switching scene during unlock added * Added warning scene and transfer to it * Moved unlock scene logic to separate files * Magic number changed * New felica render logic * Felica scenes adjusted according to design requirements * Felica poller cleanups * Some asserts added and some fixed * Replcaed asserts to checks in public api * Fixed pvs warnings in felica_poller * New event for felica_poller added for incomplete read actions * Handling of new poller event added * Update SConscript with felica files * Update api_symbols.csv with felica functions * Sync API versions Co-authored-by: あく <alleteam@gmail.com>
161 lines
4.4 KiB
C
161 lines
4.4 KiB
C
#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)
|
|
|
|
#define FELICA_POLLER_CMD_POLLING_REQ_CODE (0x00U)
|
|
#define FELICA_POLLER_CMD_POLLING_RESP_CODE (0x01U)
|
|
|
|
typedef enum {
|
|
FelicaPollerStateIdle,
|
|
FelicaPollerStateActivated,
|
|
FelicaPollerStateAuthenticateInternal,
|
|
FelicaPollerStateAuthenticateExternal,
|
|
FelicaPollerStateReadBlocks,
|
|
FelicaPollerStateReadSuccess,
|
|
FelicaPollerStateReadFailed,
|
|
|
|
FelicaPollerStateNum
|
|
} FelicaPollerState;
|
|
|
|
struct FelicaPoller {
|
|
Nfc* nfc;
|
|
FelicaPollerState state;
|
|
FelicaAuthentication auth;
|
|
|
|
FelicaData* data;
|
|
BitBuffer* tx_buffer;
|
|
BitBuffer* rx_buffer;
|
|
|
|
NfcGenericEvent general_event;
|
|
FelicaPollerEvent felica_event;
|
|
FelicaPollerEventData felica_event_data;
|
|
NfcGenericCallback callback;
|
|
uint8_t block_index;
|
|
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;
|
|
|
|
typedef struct {
|
|
uint8_t service_code : 4;
|
|
uint8_t access_mode : 3;
|
|
uint8_t length : 1;
|
|
uint8_t block_number;
|
|
} FelicaBlockListElement;
|
|
|
|
#pragma pack(push, 1)
|
|
typedef struct {
|
|
uint8_t code;
|
|
FelicaIDm idm;
|
|
uint8_t service_num;
|
|
uint16_t service_code;
|
|
uint8_t block_count;
|
|
} FelicaCommandHeader;
|
|
#pragma pack(pop)
|
|
|
|
typedef struct {
|
|
uint8_t length;
|
|
uint8_t response_code;
|
|
FelicaIDm idm;
|
|
uint8_t SF1;
|
|
uint8_t SF2;
|
|
uint8_t block_count;
|
|
uint8_t data[];
|
|
} FelicaPollerReadCommandResponse;
|
|
|
|
typedef struct {
|
|
uint8_t length;
|
|
uint8_t response_code;
|
|
FelicaIDm idm;
|
|
uint8_t SF1;
|
|
uint8_t SF2;
|
|
} FelicaPollerWriteCommandResponse;
|
|
|
|
const FelicaData* felica_poller_get_data(FelicaPoller* instance);
|
|
|
|
/**
|
|
* @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
|
|
*/
|
|
FelicaError felica_poller_polling(
|
|
FelicaPoller* instance,
|
|
const FelicaPollerPollingCommand* cmd,
|
|
FelicaPollerPollingResponse* resp);
|
|
|
|
/**
|
|
* @brief Performs felica read operation for blocks 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 reading procedure
|
|
* @param[in] block_numbers Array with block indexes according to felica docs
|
|
* @param[out] response_ptr Pointer to the response structure
|
|
* @return FelicaErrorNone on success, an error code on failure.
|
|
*/
|
|
FelicaError felica_poller_read_blocks(
|
|
FelicaPoller* instance,
|
|
const uint8_t block_count,
|
|
const uint8_t* const block_numbers,
|
|
FelicaPollerReadCommandResponse** const response_ptr);
|
|
|
|
/**
|
|
* @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);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|